mirror of
https://github.com/zellyn/diskii.git
synced 2024-11-28 10:52:00 +00:00
prodos: working on loading Volume
This commit is contained in:
parent
1758fc0f32
commit
c244ec5257
@ -19,6 +19,7 @@ type Descriptor struct {
|
||||
Name string
|
||||
Fullname string // If there's a more complete filename (eg. Super-Mon), put it here.
|
||||
Sectors int
|
||||
Blocks int
|
||||
Length int
|
||||
Locked bool
|
||||
Type Filetype
|
||||
|
@ -340,6 +340,18 @@ type FileDescriptor struct {
|
||||
HeaderPointer uint16 // Block number of the key block for the directory which describes this file.
|
||||
}
|
||||
|
||||
// descriptor returns a disk.Descriptor for a FileDescriptor.
|
||||
func (fd FileDescriptor) descriptor() disk.Descriptor {
|
||||
desc := disk.Descriptor{
|
||||
Name: fd.Name(),
|
||||
Blocks: int(fd.BlocksUsed),
|
||||
Length: int(fd.Eof[0]) + int(fd.Eof[1])<<8 + int(fd.Eof[2])<<16,
|
||||
Locked: false, // TODO(zellyn): use prodos-style access in disk.Descriptor
|
||||
Type: disk.Filetype(fd.FileType),
|
||||
}
|
||||
return desc
|
||||
}
|
||||
|
||||
// Name returns the string filename of a file descriptor.
|
||||
func (fd FileDescriptor) Name() string {
|
||||
return string(fd.FileName[0 : fd.TypeAndNameLength&0xf])
|
||||
@ -580,6 +592,51 @@ func (sh SubdirectoryHeader) Name() string {
|
||||
return string(sh.SubdirectoryName[0 : sh.TypeAndNameLength&0xf])
|
||||
}
|
||||
|
||||
// Volume is the in-memory representation of a device's volume
|
||||
// information.
|
||||
type Volume struct {
|
||||
keyBlock *VolumeDirectoryKeyBlock
|
||||
blocks []*VolumeDirectoryBlock
|
||||
bitmap *VolumeBitMap
|
||||
subdirs map[uint16]*Subdirectory
|
||||
}
|
||||
|
||||
// Subdirectory is the in-memory representation of a single
|
||||
// subdirectory's information.
|
||||
type Subdirectory struct {
|
||||
keyBlock *SubdirectoryKeyBlock
|
||||
blocks []*SubdirectoryBlock
|
||||
}
|
||||
|
||||
// readVolume reads the entire volume and subdirectories frmo a disk
|
||||
// into memory.
|
||||
func readVolume(bd disk.BlockDevice) (Volume, error) {
|
||||
v := Volume{
|
||||
keyBlock: &VolumeDirectoryKeyBlock{},
|
||||
subdirs: make(map[uint16]*Subdirectory),
|
||||
}
|
||||
|
||||
if err := disk.UnmarshalBlock(bd, v.keyBlock, 2); err != nil {
|
||||
return v, fmt.Errorf("cannot read first block of volume directory (block 2): %v", err)
|
||||
}
|
||||
|
||||
if vbm, err := ReadVolumeBitMap(bd, v.keyBlock.Header.BitMapPointer); err != nil {
|
||||
return v, err
|
||||
} else {
|
||||
v.bitmap = &vbm
|
||||
}
|
||||
|
||||
for block := v.keyBlock.Next; block != 0; block = v.blocks[len(v.blocks)-1].Next {
|
||||
vdb := VolumeDirectoryBlock{}
|
||||
if err := disk.UnmarshalBlock(bd, &vdb, block); err != nil {
|
||||
return v, err
|
||||
}
|
||||
v.blocks = append(v.blocks, &vdb)
|
||||
}
|
||||
|
||||
return v, nil
|
||||
}
|
||||
|
||||
// copyBytes is just like the builtin copy, but just for byte slices,
|
||||
// and it checks that dst and src have the same length.
|
||||
func copyBytes(dst, src []byte) int {
|
||||
|
Loading…
Reference in New Issue
Block a user