Class ProdosFileEntry
java.lang.Object
com.webcodepro.applecommander.storage.os.prodos.ProdosCommonEntry
com.webcodepro.applecommander.storage.os.prodos.ProdosFileEntry
- All Implemented Interfaces:
FileEntry
- Direct Known Subclasses:
ProdosDirectoryEntry
Represents a ProDOS file entry on disk.
Date created: Oct 5, 2002 6:01:15 PM
-
Field Summary
Fields inherited from class com.webcodepro.applecommander.storage.os.prodos.ProdosCommonEntry
ENTRY_LENGTH -
Constructor Summary
ConstructorsConstructorDescriptionProdosFileEntry(ProdosFormatDisk disk, int block, int offset) Constructor for ProdosFileEntry. -
Method Summary
Modifier and TypeMethodDescriptionvoiddelete()Delete the file.intGet the address that this file loads at.intGet the auxiliary type for this file.intGet the number of blocks used.intGet the EOF position.getFileColumnData(int displayMode) Get the standard file column header information.byte[]Get file data.Return the name of this file.Return the filetype of this file.intReturn the ProDOS file type as a hex string.intGet the block number of the key block for the directory which describes this file.intGet the key pointer.Get the last modification date.intReturn the maximum filename length.intgetSize()Compute the size of this file (in bytes).Get the suggested FileFilter.booleanIndicate if this is an AppleWorks file.booleanIdentify if this file has been deleted.booleanIdentify if this is a directory file.booleanIndicate if this is a GEOS file.booleanIndicate if this is a GEOS file.booleanisLocked()Identify if this file is locked.booleanIndicates if this filetype requires an address component.voidsetAddress(int address) Set the address that this file loads at.voidsetAuxiliaryType(byte[] entry, byte low, byte high) Set the auxiliary type for this file.voidsetAuxiliaryType(byte[] entry, int auxiliaryType) Set the auxiliary type for this file.voidsetAuxiliaryType(int auxiliaryType) Set the auxiliary type for this file.voidsetBlocksUsed(int blocksUsed) Set the number of blocks used.voidsetEofPosition(int eofPosition) Set the EOF position.voidsetFileData(byte[] data) Set the file data.voidsetFileData(byte[] dataFork, byte[] resourceFork) Set the file data, with the expectation that both data and resource forks are present (storage type $05).voidsetFilename(String filename) Set the name of this file.voidsetFiletype(long fileType) Set the filetype based on a long - thunk into a bytevoidsetFiletype(String filetype) Set the filetype based on a string value.voidsetGEOSMeta(byte[] metaData) Copy GEOS-specific metadata to the directory entry verbatim: Bytes $00-$10 ($11 bytes) Bytes $18-$1d ($06 bytes) Bytes $21-$24 ($04 bytes)voidsetHeaderPointer(int headerPointer) Set the block number of the block for the directory which describes this file.voidsetKeyPointer(int keyPointer) Set the key pointer.voidsetLastModificationDate(Date date) Set the last modification date.voidsetLocked(boolean lock) Set the lock indicator.Methods inherited from class com.webcodepro.applecommander.storage.os.prodos.ProdosCommonEntry
canDestroy, canRead, canRename, canWrite, getAccess, getCreationDate, getDisk, getFileEntryBlock, getFormattedDisk, getMinimumProdosVersion, getProdosVersion, getStorageType, hasChanged, isEmpty, isSaplingFile, isSeedlingFile, isSubdirectory, isSubdirectoryHeader, isTreeFile, isVolumeHeader, readFileEntry, setAccess, setCanDestroy, setCanRead, setCanRename, setCanWrite, setCreationDate, setHasChanged, setMinimumProdosVersion, setProdosVersion, setSaplingFile, setSeedlingFile, setStorageType, setSubdirectory, setSubdirectoryHeader, setTreeFile, setVolumeHeader, writeFileEntryMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.webcodepro.applecommander.storage.FileEntry
getFormattedDisk
-
Constructor Details
-
ProdosFileEntry
Constructor for ProdosFileEntry.
-
-
Method Details
-
getFilename
Return the name of this file. This handles normal files, deleted files, and AppleWorks files - which use the AUXTYPE attribute to indicate upper/lowercase in the filename.- Specified by:
getFilenamein interfaceFileEntry
-
getMaximumFilenameLength
public int getMaximumFilenameLength()Return the maximum filename length.- Specified by:
getMaximumFilenameLengthin interfaceFileEntry
-
setFilename
Set the name of this file.- Specified by:
setFilenamein interfaceFileEntry
-
setGEOSMeta
public void setGEOSMeta(byte[] metaData) Copy GEOS-specific metadata to the directory entry verbatim: Bytes $00-$10 ($11 bytes) Bytes $18-$1d ($06 bytes) Bytes $21-$24 ($04 bytes) -
getFiletype
Return the filetype of this file. This will be three characters, according to ProDOS - a "$xx" if unknown.- Specified by:
getFiletypein interfaceFileEntry
-
getFiletypeByte
public int getFiletypeByte() -
setFiletype
Set the filetype based on a string value.- Specified by:
setFiletypein interfaceFileEntry
-
setFiletype
public void setFiletype(long fileType) Set the filetype based on a long - thunk into a byte -
isAppleWorksFile
public boolean isAppleWorksFile()Indicate if this is an AppleWorks file. Intended to force upper/lowercase into the filename. -
isGEOSFile
public boolean isGEOSFile()Indicate if this is a GEOS file. -
isForkedFile
public boolean isForkedFile()Indicate if this is a GEOS file. -
getKeyPointer
public int getKeyPointer()Get the key pointer. This is either the data block (seedling), index block (sapling), or master index block (tree). -
setKeyPointer
public void setKeyPointer(int keyPointer) Set the key pointer. This is either the data block (seedling), index block (sapling), or master index block (tree). -
getBlocksUsed
public int getBlocksUsed()Get the number of blocks used. -
setBlocksUsed
public void setBlocksUsed(int blocksUsed) Set the number of blocks used. -
getEofPosition
public int getEofPosition()Get the EOF position. This can indicate the length of a file. -
setEofPosition
public void setEofPosition(int eofPosition) Set the EOF position. -
getAuxiliaryType
public int getAuxiliaryType()Get the auxiliary type for this file. TXT - random access record length. BIN - load address for binary image. BAS - load address for program image. VAR - address of compressed variables image. SYS - load address for system program (usually 0x2000). AWP/ADB/ASP - upper/lowercase flags -
setAuxiliaryType
public void setAuxiliaryType(int auxiliaryType) Set the auxiliary type for this file. -
setAuxiliaryType
public void setAuxiliaryType(byte[] entry, byte low, byte high) Set the auxiliary type for this file. -
setAuxiliaryType
public void setAuxiliaryType(byte[] entry, int auxiliaryType) Set the auxiliary type for this file. -
getLastModificationDate
Get the last modification date. -
setLastModificationDate
Set the last modification date. -
getHeaderPointer
public int getHeaderPointer()Get the block number of the key block for the directory which describes this file. -
setHeaderPointer
public void setHeaderPointer(int headerPointer) Set the block number of the block for the directory which describes this file. -
isLocked
public boolean isLocked()Identify if this file is locked. -
setLocked
public void setLocked(boolean lock) Set the lock indicator. -
getSize
public int getSize()Compute the size of this file (in bytes). -
isDirectory
public boolean isDirectory()Identify if this is a directory file.- Specified by:
isDirectoryin interfaceFileEntry
-
isDeleted
public boolean isDeleted()Identify if this file has been deleted. -
delete
public void delete()Delete the file. -
getFileColumnData
Get the standard file column header information. This default implementation is intended only for standard mode. displayMode is specified in FormattedDisk.- Specified by:
getFileColumnDatain interfaceFileEntry
-
getFileTypeString
Return the ProDOS file type as a hex string. -
getFileData
public byte[] getFileData()Get file data. This handles any operating-system specific issues. Currently, the disk itself handles this.- Specified by:
getFileDatain interfaceFileEntry
-
setFileData
Set the file data. This is essentially the save operation. Specifically, if the filetype is binary, the length and address need to be set. If the filetype is applesoft or integer basic, the start address needs to be set.- Specified by:
setFileDatain interfaceFileEntry- Throws:
DiskFullException
-
setFileData
Set the file data, with the expectation that both data and resource forks are present (storage type $05). See: http://www.1000bit.it/support/manuali/apple/technotes/pdos/tn.pdos.25.html- Throws:
DiskFullException
-
getSuggestedFilter
Get the suggested FileFilter. This appears to be operating system specific, so each operating system needs to implement some manner of guessing the appropriate filter.- Specified by:
getSuggestedFilterin interfaceFileEntry
-
needsAddress
public boolean needsAddress()Indicates if this filetype requires an address component. Note that the FormattedDisk also has this method - normally, this will defer to the method on FormattedDisk, as it will be more generic.- Specified by:
needsAddressin interfaceFileEntry
-
setAddress
public void setAddress(int address) Set the address that this file loads at.- Specified by:
setAddressin interfaceFileEntry
-
getAddress
public int getAddress()Get the address that this file loads at.- Specified by:
getAddressin interfaceFileEntry
-