Дополнительные команды AVR-DOS — различия между версиями
MiBBiM (обсуждение | вклад) (Новая: '''Список команд DOS''' — нижеследующий список команд для [[операционная си...) |
MiBBiM (обсуждение | вклад) (понемножку добавляю команды) |
||
Строка 1: | Строка 1: | ||
− | '''Список команд DOS''' — нижеследующий список | + | '''Список команд AVR-DOS''' — нижеследующий список команд для операционной системы [[Запускаем AVR-DOS на SD-Card МиниБота|AVR-DOS]]. |
− | + | == Диск/Директория == | |
− | + | === InitFileSystem === | |
− | + | Читает Master boot record и partition boot record (Sector) флэшкарты и инициализирует файловую систему. | |
− | |||
− | |||
− | |||
− | |||
− | + | '''Эта функция должна быть вызвана перед любым другим использованием системы!''' | |
− | |||
− | + | <code>bErrorCode = InitFileSystem (bPartitionNumber)</code> | |
− | </ | ||
− | + | {| class="wikitable" | |
+ | | bErrorCode(Byte) | ||
+ | | Error Result from Routine, Returns 0 if no Error | ||
+ | |- | ||
+ | | bPartitionNumber(Byte) | ||
+ | | Partitionnumber on the Flashcard Drive (normally 1, but use 0 on mediums without Master boot record) | ||
+ | |} | ||
− | + | Пример вызова: | |
− | |||
− | |||
− | + | <pre>Dim bErrorCode as Byte | |
+ | bErrorCode = InitFileSystem(1) | ||
+ | If bErrorCode > 0 then | ||
+ | Print "Error: " ; bErrorCode | ||
+ | Else | ||
+ | Print "Filesystem successfully initialized" | ||
+ | End If | ||
+ | </pre> | ||
− | + | === DiskSize === | |
− | + | Возвращает размер диска. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | <code>lSize = DiskSize ()</code> | |
− | = | + | {| class="wikitable" |
− | + | | lSize(Long) | |
+ | | Объем диска в КБайтах | ||
+ | |} | ||
− | + | Пример вызова: | |
− | |||
− | |||
− | |||
− | + | <pre>Dim Gbtemp1 As Byte ' scratch byte | |
+ | Gbtemp1 = Initfilesystem(1) ' we must init the filesystem once | ||
+ | If Gbtemp1 > 0 Then | ||
+ | Print #1 , "Error " ; Gbtemp1 | ||
+ | Else | ||
+ | Print #1 , " OK" | ||
+ | Print "Disksize : " ; Disksize() ' show disk size in Kbytes | ||
+ | Print "Disk free: " ; Diskfree() ' show free space too | ||
+ | End If | ||
+ | </pre> | ||
− | + | === DiskFree === | |
− | + | Возвращает размер свободного пространства диска. | |
− | + | <code>lFreeSize = DiskFree ()</code> | |
− | |||
− | + | {| class="wikitable" | |
+ | | lFreeSize(Long) | ||
+ | | Размер свободной области в КБайтах | ||
+ | |} | ||
− | + | Пример вызова: | |
− | |||
− | |||
− | + | <pre>Dim Gbtemp1 As Byte ' scratch byte | |
− | + | Gbtemp1 = Initfilesystem(1) ' we must init the filesystem once | |
− | + | If Gbtemp1 > 0 Then | |
+ | Print #1 , "Error " ; Gbtemp1 | ||
+ | Else | ||
+ | Print #1 , " OK" | ||
+ | Print "Disksize : " ; Disksize() ' show disk size in Kbytes | ||
+ | Print "Disk free: " ; Diskfree() ' show free space too | ||
+ | End If | ||
+ | </pre> | ||
− | + | === Kill === | |
+ | Удаляет файл с диска. Открытый файл не может быть удален. Специальные символы(WildCards) в имени файла, маски не поддерживаются. Код ошибки хранится в глобальной переменной gDOSError. | ||
− | + | <code>Kill sFileName</code> | |
− | + | {| class="wikitable" | |
+ | | sFileName(String) | ||
+ | | Полный или относительный(?) путь к файлу | ||
+ | |} | ||
− | + | Пример вызова: | |
− | : | ||
− | + | <pre>'We can use the KILL statement to delete a file. | |
− | + | 'A file mask is not supported | |
+ | Print "Kill (delete) file demo" | ||
+ | Kill "test.txt" | ||
+ | </pre> | ||
+ | === Dir === | ||
+ | Возвращает имя файла, удовлетворяющее маске. | ||
− | + | Первый вызов функции содержит маску. Все последующие вызовы совершаются без маски. Фактически, когда вы хотите получить имя следующего файла в данной директории, удовлетворяющее маске, вы должны вызывать вариант функции без параметров после первого вызова. | |
+ | <code>sFile = Dir(mask)</code> | ||
+ | <code>sFile = Dir()</code> | ||
− | + | {| class="wikitable" | |
− | + | | SFile(String) | |
− | + | | Имя файла. Строка пуста, если больше нет файлов, удовлетворяющих маске. | |
− | + | |- | |
− | + | | Mask(String) | |
− | + | | Файловая маска, удовлетворяющая требованиям обычного DOS, напр. '*.TXT'. Маска *.* удовлетворяет всем файлам | |
− | + | |} | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | Пример вызова: | ||
− | + | <pre>'Lets have a look at the file we created | |
− | + | Print "Dir function demo" | |
− | + | S = Dir( "*.*") | |
+ | 'The first call to the DIR() function must contain a file mask | ||
+ | ' The * means everything. | ||
+ | ' | ||
+ | While Len(s) > 0 ' if there was a file found | ||
+ | Print S ; " " ; Filedate() ; " " ; Filetime() ; " " ; Filelen() | ||
+ | ' print file , the date the fime was created/changed , the time and the size of the file | ||
+ | S = Dir() ' get next | ||
+ | Wend | ||
+ | </pre> | ||
− | === | + | === FileLen === |
− | + | === FileDateTime === | |
+ | === FileDate === | ||
+ | === FileTime === | ||
+ | === GetAttr === | ||
+ | === Name === | ||
+ | === ChDir === | ||
+ | === MkDir === | ||
+ | === RmDir === | ||
− | + | == Файлы == | |
− | + | === FreeFile === | |
+ | === Open === | ||
+ | Открывает устройство | ||
− | + | <code>OPEN "device" for MODE As #channel</code> | |
− | |||
− | + | <code>OPEN file FOR MODE as #channel</code> | |
− | |||
− | + | {| class="wikitable" | |
− | + | | Device | |
− | + | | The default device is COM1 and you don't need to open a channel to use INPUT/OUTPUT on this device. | |
+ | With the implementation of the software UART, the compiler must know to which pin/device you will send/receive the data. | ||
+ | So that is why the OPEN statement must be used. It tells the compiler about the pin you use for the serial input or output and the baud rate you want to use. | ||
+ | COMB.0:9600,8,N,2 will use PORT B.0 at 9600 baud with 2 stopbits. | ||
− | + | The format for COM1 and COM2 is : COM1: or COM2: | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | There is no speed/baud rate parameter since the default baud rate will be used that is specified with $BAUD or $BAUD1 | |
− | + | The format for the software UART is: COMpin:speed,8,N,stopbits[,INVERTED] | |
− | + | Where pin is the name of the PORT-pin. | |
− | + | Speed must be specified and stop bits can be 1 or 2. | |
+ | 7 bit data or 8 bit data may be used. | ||
+ | For parity N, O or E can be used. | ||
− | + | An optional parameter ,INVERTED can be specified to use inverted RS-232. | |
− | : | + | Open "COMD.1:9600,8,N,1,INVERTED" For Output As #1 , will use pin PORTD.1 for output with 9600 baud, 1 stop bit and with inverted RS-232. |
− | + | ||
− | + | For the AVR-DOS filesystem, Device can also be a string or filename constant like | |
− | + | "readme.txt" or sFileName | |
− | + | |- | |
+ | | Mode | ||
+ | | You can use BINARY or RANDOM for COM1 and COM2, but for the software UART pins, you must specify INPUT or OUTPUT. | ||
− | + | For the AVR-DOS filesystem, MODE may be INPUT, OUTPUT, APPEND or BINARY. | |
− | + | |- | |
+ | | Channel | ||
+ | | The number of the channel to open. Must be a positive constant >0. | ||
− | + | For the AVR-DOS filesystem, the channel may be a positive constant or a numeric variable. Note that the AVD-DOS filesystem uses real filehandles. The software UART does not use real file handles. | |
− | + | |} | |
− | + | Пример вызова: | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | <pre>OPEN "com1:" for binary as #1 | |
− | + | Call test | |
− | + | End | |
+ | Sub test | ||
+ | Print #1, "test" | ||
+ | End Sub | ||
+ | Close #1 | ||
+ | </pre> | ||
− | === | + | === Close === |
− | + | === Flush === | |
+ | === Print === | ||
+ | === Write === | ||
+ | === Input === | ||
+ | === Line Input === | ||
+ | === Get === | ||
+ | === Put === | ||
+ | === Seek === | ||
− | + | == Свойства файла == | |
+ | === EOF === | ||
+ | === LOC === | ||
+ | === LO === | ||
+ | === FileAttr === | ||
− | + | == Другие == | |
− | + | === Bload === | |
− | + | === Bsave === | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
== См. также == | == См. также == | ||
* [[Запускаем AVR-DOS на SD-Card МиниБота]] | * [[Запускаем AVR-DOS на SD-Card МиниБота]] | ||
− | + | * [http://members.aon.at/voegel/index.html Официальная страница AVR-DOS] | |
− | |||
− | |||
[[Категория:МиниБот]] | [[Категория:МиниБот]] |
Версия 11:13, 6 января 2009
Список команд AVR-DOS — нижеследующий список команд для операционной системы AVR-DOS.
Содержание
Диск/Директория
InitFileSystem
Читает Master boot record и partition boot record (Sector) флэшкарты и инициализирует файловую систему.
Эта функция должна быть вызвана перед любым другим использованием системы!
bErrorCode = InitFileSystem (bPartitionNumber)
bErrorCode(Byte) | Error Result from Routine, Returns 0 if no Error |
bPartitionNumber(Byte) | Partitionnumber on the Flashcard Drive (normally 1, but use 0 on mediums without Master boot record) |
Пример вызова:
Dim bErrorCode as Byte bErrorCode = InitFileSystem(1) If bErrorCode > 0 then Print "Error: " ; bErrorCode Else Print "Filesystem successfully initialized" End If
DiskSize
Возвращает размер диска.
lSize = DiskSize ()
lSize(Long) | Объем диска в КБайтах |
Пример вызова:
Dim Gbtemp1 As Byte ' scratch byte Gbtemp1 = Initfilesystem(1) ' we must init the filesystem once If Gbtemp1 > 0 Then Print #1 , "Error " ; Gbtemp1 Else Print #1 , " OK" Print "Disksize : " ; Disksize() ' show disk size in Kbytes Print "Disk free: " ; Diskfree() ' show free space too End If
DiskFree
Возвращает размер свободного пространства диска.
lFreeSize = DiskFree ()
lFreeSize(Long) | Размер свободной области в КБайтах |
Пример вызова:
Dim Gbtemp1 As Byte ' scratch byte Gbtemp1 = Initfilesystem(1) ' we must init the filesystem once If Gbtemp1 > 0 Then Print #1 , "Error " ; Gbtemp1 Else Print #1 , " OK" Print "Disksize : " ; Disksize() ' show disk size in Kbytes Print "Disk free: " ; Diskfree() ' show free space too End If
Kill
Удаляет файл с диска. Открытый файл не может быть удален. Специальные символы(WildCards) в имени файла, маски не поддерживаются. Код ошибки хранится в глобальной переменной gDOSError.
Kill sFileName
sFileName(String) | Полный или относительный(?) путь к файлу |
Пример вызова:
'We can use the KILL statement to delete a file. 'A file mask is not supported Print "Kill (delete) file demo" Kill "test.txt"
Dir
Возвращает имя файла, удовлетворяющее маске.
Первый вызов функции содержит маску. Все последующие вызовы совершаются без маски. Фактически, когда вы хотите получить имя следующего файла в данной директории, удовлетворяющее маске, вы должны вызывать вариант функции без параметров после первого вызова.
sFile = Dir(mask)
sFile = Dir()
SFile(String) | Имя файла. Строка пуста, если больше нет файлов, удовлетворяющих маске. |
Mask(String) | Файловая маска, удовлетворяющая требованиям обычного DOS, напр. '*.TXT'. Маска *.* удовлетворяет всем файлам |
Пример вызова:
'Lets have a look at the file we created Print "Dir function demo" S = Dir( "*.*") 'The first call to the DIR() function must contain a file mask ' The * means everything. ' While Len(s) > 0 ' if there was a file found Print S ; " " ; Filedate() ; " " ; Filetime() ; " " ; Filelen() ' print file , the date the fime was created/changed , the time and the size of the file S = Dir() ' get next Wend
FileLen
FileDateTime
FileDate
FileTime
GetAttr
Name
ChDir
MkDir
RmDir
Файлы
FreeFile
Open
Открывает устройство
OPEN "device" for MODE As #channel
OPEN file FOR MODE as #channel
Device | The default device is COM1 and you don't need to open a channel to use INPUT/OUTPUT on this device.
With the implementation of the software UART, the compiler must know to which pin/device you will send/receive the data. So that is why the OPEN statement must be used. It tells the compiler about the pin you use for the serial input or output and the baud rate you want to use. COMB.0:9600,8,N,2 will use PORT B.0 at 9600 baud with 2 stopbits. The format for COM1 and COM2 is : COM1: or COM2: There is no speed/baud rate parameter since the default baud rate will be used that is specified with $BAUD or $BAUD1 The format for the software UART is: COMpin:speed,8,N,stopbits[,INVERTED] Where pin is the name of the PORT-pin. Speed must be specified and stop bits can be 1 or 2. 7 bit data or 8 bit data may be used. For parity N, O or E can be used. An optional parameter ,INVERTED can be specified to use inverted RS-232. Open "COMD.1:9600,8,N,1,INVERTED" For Output As #1 , will use pin PORTD.1 for output with 9600 baud, 1 stop bit and with inverted RS-232.
For the AVR-DOS filesystem, Device can also be a string or filename constant like "readme.txt" or sFileName |
Mode | You can use BINARY or RANDOM for COM1 and COM2, but for the software UART pins, you must specify INPUT or OUTPUT.
For the AVR-DOS filesystem, MODE may be INPUT, OUTPUT, APPEND or BINARY. |
Channel | The number of the channel to open. Must be a positive constant >0.
For the AVR-DOS filesystem, the channel may be a positive constant or a numeric variable. Note that the AVD-DOS filesystem uses real filehandles. The software UART does not use real file handles. |
Пример вызова:
OPEN "com1:" for binary as #1 Call test End Sub test Print #1, "test" End Sub Close #1