cocofs is a simple tool for interacting with TRS-80 Color Computer disk images that are formatted with the file system supported by Disk Extended Color Basic. This file system is very simple and closely resembles the FAT file system used in MS-DOS. Information about the file system format can be found here, but here are the basics:
- single-sided (1 track-per-cylinder), double-density
- 35 cylinders (numbered 0 - 34)
- 18 sectors-per-track (numbered 1 - 18)
- 256 bytes-per-sector
Each track is broken up into 2 "granules" of 9 sectors. The granule is the file system's allocation unit. With 35 tracks, there are a total of 70 granules. The directory is stored in track 17, leaving 68 granules available for file data.
cocofs currently supports simple linear disk images that are 161280 bytes in size (35 * 18 * 256). These files often have the .DSK file name extension.
cocofs is pretty easy to use. The general form is:
cocofs IMAGE.DSK operation
cocofs can perform the following operations:
- format -- create a new disk image
- ls [file1 [file2 [...]]] -- list the directory or specific files
- copyin file1 [file2 [...]] -- copy files into the disk image
- copyout file1 [file2 [...]] -- copy files out of the disk image
- rm file1 [file2 [...]] -- remove files from the disk image
- dump -- dump information about the disk image, file allocation, etc.
So, for example:
% cocofs EDTASM++.DSK ls
  EDTASM++   BIN   10762 bytes (Code, Binary)
  TRANSFER   BAS     573 bytes (Basic, Binary)
  EDTASM++   ASM    5138 bytes (Data, ASCII)
  EDITASM+   BIN   10250 bytes (Code, Binary)
  EDPATCH    BAS     488 bytes (Basic, Binary)
  EDLOADER   BAS     430 bytes (Basic, Binary)
  SUPERED+   BIN   10762 bytes (Code, Binary)
  SUPERED    BIN   10762 bytes (Code, Binary)
8 files, 42 granules (96768 bytes) free
% cocofs TEST.DSK format
% cocofs TEST.DSK ls
0 files, 68 granules (156672 bytes) free
% cocofs TEST.DSK copyin /path/to/foo.txt
% cocofs TEST.DSK ls
  FOO        TXT      45 bytes (Text, ASCII)
  
1 file, 67 granules (154368 bytes) free
% cocofs EDTASM++.DSK copyout transfer.bas
% ls -l TRANSFER.BAS
4 -rw-r--r--  1 thorpej  wheel  573 Jul  6 16:40 TRANSFER.BAS
% strings TRANSFER.BAS | head -2
"EDTASM+ SOURCE CODE"
"FILE TRANSFER UTILITY"
%
This tool isn't super advanced, and could still be improved, but it is useful in its current form. Some ideas for future enhancements:
- fsck functionality -- the ability to check and repair CoCo file systems
- more advanced command parsing for copyin and copyout.
- rename functionality -- the ability to rename files in the file system
- support for more disk image formats
cocofs should be extremely portable to any Unix-like system with a C99 compiler, and can also be built for Windows using MinGW-w64 (see Makefile for details). Please let me know if you have issues building it on your system.
If you're intrested in contributing, please do! In any case, I hope you find this tool useful!