2019-07-15 14:21:50 +02:00
|
|
|
[< back to index](../doc_index.md)
|
2019-01-05 01:19:14 +01:00
|
|
|
|
|
|
|
## cbm_file
|
|
|
|
|
|
|
|
The `cbm_file` module provides support for loading and saving files to tape and disk.
|
|
|
|
Currently, it works only for Commodore 64 targets, although support for more targets is coming.
|
|
|
|
It uses Kernal routines, so it requires the Kernal ROM to be enabled.
|
|
|
|
|
|
|
|
#### byte last_used_device()
|
|
|
|
|
|
|
|
Returns the last device number, or 8 if none.
|
|
|
|
|
|
|
|
#### void load_file(byte device, pointer name)
|
|
|
|
|
|
|
|
Loads a PRG file with the given null-terminated name to the address specified in the file.
|
|
|
|
Sets `errno`.
|
|
|
|
|
|
|
|
#### void load_file_at(byte device, pointer name, pointer addr)
|
|
|
|
|
|
|
|
Loads a PRG file with the given null-terminated name to the given address.
|
|
|
|
Sets `errno`.
|
|
|
|
|
|
|
|
#### void save_file(byte device, pointer name, pointer start, word length)
|
|
|
|
|
|
|
|
Saves `length` bytes starting from `start` to a PRG file named `name` on device `device`.
|
|
|
|
Sets `errno`.
|
|
|
|
|
|
|
|
#### void exec_disk(byte device, pointer command)
|
|
|
|
|
|
|
|
Executes a CBM DOS command on the given drive.
|
|
|
|
|
|
|
|
#### void delete_file(byte device, pointer name)
|
|
|
|
|
2020-12-01 14:26:47 +01:00
|
|
|
Deletes the given file in the given drive. (`S0:`)
|
2019-01-05 01:19:14 +01:00
|
|
|
|
|
|
|
#### void rename_file(byte device, pointer old_name, pointer new_name)
|
|
|
|
|
2020-12-01 14:26:47 +01:00
|
|
|
Renames the given file in the given drive. (`R0:`)
|
2019-01-05 01:19:14 +01:00
|
|
|
|
|
|
|
#### void copy_file(byte device, pointer old_name, pointer new_name)
|
|
|
|
|
|
|
|
Copies given file in the given drive. (`C0:`)
|
|
|
|
|
|
|
|
#### void initialize_disk(byte device)
|
|
|
|
|
|
|
|
Reinitialized disk status in the given drive. (`I0`)
|
|
|
|
|
|
|
|
#### void validate_disk(byte device)
|
|
|
|
|
|
|
|
Validates disk status in the given drive. (`V0`)
|
|
|
|
|
|
|
|
#### void format_disk(byte device)
|
|
|
|
|
|
|
|
Formats disk status in the given drive. (`N0:`)
|
|
|
|
|
|
|
|
#### void open_file(byte device, pointer name, byte fd, byte mode)
|
|
|
|
|
|
|
|
Opens a file.
|
|
|
|
Sets `errno`.
|
|
|
|
TODO: buggy.
|
|
|
|
|
|
|
|
#### const byte MODE_READ = 0
|
|
|
|
#### const byte MODE_WRITE = 1
|
|
|
|
|
|
|
|
#### void close_file(byte fd)
|
|
|
|
|
|
|
|
Closes the given file.
|
|
|
|
Sets `errno`.
|
|
|
|
TODO: buggy.
|
|
|
|
|
|
|
|
#### byte getbyte_safe()
|
|
|
|
|
|
|
|
Reads a byte from file.
|
|
|
|
Sets `errno` to `err_eof` when reading the last byte, so don't abort reading when getting `errno != err_ok`.
|
|
|
|
TODO: buggy.
|
|
|
|
|
|
|
|
#### void putbyte_safe(byte b)
|
|
|
|
|
2019-07-31 02:37:40 +02:00
|
|
|
Writes a byte from file.
|
2019-01-05 01:19:14 +01:00
|
|
|
Sets `errno`.
|
|
|
|
TODO: buggy.
|