package hotline
type fileType struct {
- TypeCode string // 4 byte type code used in file transfers
- CreatorCode string // 4 byte creator code used in file transfers
- CreatorString string // variable length string used in file get info
- FileTypeString string // variable length string used in file get info
+ TypeCode string // 4 byte type code used in file transfers
+ CreatorCode string // 4 byte creator code used in file transfers
}
var defaultFileType = fileType{
CreatorCode: "HTLC",
},
}
+
+// A small number of type codes are displayed in the GetInfo window with a friendly name instead of the 4 letter code
+var friendlyCreatorNames = map[string]string{
+ "fldr": "Folder",
+ "flda": "Folder Alias",
+ "HTft": "Incomplete File",
+ "SIT!": "StuffIt Archive",
+ "TEXT": "Text File",
+}
return defaultFileType
}
+func fileTypeFromInfo(info os.FileInfo) (ft fileType, err error) {
+ if info.IsDir() {
+ ft.CreatorCode = "n/a "
+ ft.TypeCode = "fldr"
+ } else {
+ ft = fileTypeFromFilename(info.Name())
+ }
+
+ return ft, nil
+}
+
func getFileNameList(filePath string) (fields []Field, err error) {
files, err := ioutil.ReadDir(filePath)
if err != nil {
Comment []byte // File comment
}
-func NewFlatFileInformationFork(fileName string, modifyTime []byte) FlatFileInformationFork {
+func NewFlatFileInformationFork(fileName string, modifyTime []byte, typeSignature string, creatorSignature string) FlatFileInformationFork {
return FlatFileInformationFork{
- Platform: []byte("AMAC"), // TODO: Remove hardcode to support "AWIN" Platform (maybe?)
- TypeSignature: []byte(fileTypeFromFilename(fileName).TypeCode), // TODO: Don't infer types from filename
- CreatorSignature: []byte(fileTypeFromFilename(fileName).CreatorCode), // TODO: Don't infer types from filename
- Flags: []byte{0, 0, 0, 0}, // TODO: What is this?
- PlatformFlags: []byte{0, 0, 1, 0}, // TODO: What is this?
- RSVD: make([]byte, 32), // Unimplemented in Hotline Protocol
- CreateDate: modifyTime, // some filesystems don't support createTime
+ Platform: []byte("AMAC"), // TODO: Remove hardcode to support "AWIN" Platform (maybe?)
+ TypeSignature: []byte(typeSignature), // TODO: Don't infer types from filename
+ CreatorSignature: []byte(creatorSignature), // TODO: Don't infer types from filename
+ Flags: []byte{0, 0, 0, 0}, // TODO: What is this?
+ PlatformFlags: []byte{0, 0, 1, 0}, // TODO: What is this?
+ RSVD: make([]byte, 32), // Unimplemented in Hotline Protocol
+ CreateDate: modifyTime, // some filesystems don't support createTime
ModifyDate: modifyTime,
NameScript: make([]byte, 2), // TODO: What is this?
Name: []byte(fileName),
}
}
+func (ffif *FlatFileInformationFork) friendlyType() []byte {
+
+ if name, ok := friendlyCreatorNames[string(ffif.TypeSignature)]; ok {
+ return []byte(name)
+ }
+ return ffif.CreatorSignature
+}
+
// DataSize calculates the size of the flat file information fork, which is
// 72 bytes for the fixed length fields plus the length of the Name + Comment
func (ffif *FlatFileInformationFork) DataSize() []byte {
mTime := toHotlineTime(fileInfo.ModTime())
+ ft, _ := fileTypeFromInfo(fileInfo)
+
return &flattenedFileObject{
FlatFileHeader: NewFlatFileHeader(),
- FlatFileInformationFork: NewFlatFileInformationFork(string(fileName), mTime),
+ FlatFileInformationFork: NewFlatFileInformationFork(string(fileName), mTime, ft.TypeCode, ft.CreatorCode),
FlatFileDataForkHeader: FlatFileDataForkHeader{
ForkType: [4]byte{0x44, 0x41, 0x54, 0x41}, // "DATA"
CompressionType: [4]byte{},
want: &flattenedFileObject{
FlatFileHeader: NewFlatFileHeader(),
FlatFileInformationForkHeader: FlatFileInformationForkHeader{},
- FlatFileInformationFork: NewFlatFileInformationFork("testfile.txt", make([]byte, 8)),
+ FlatFileInformationFork: NewFlatFileInformationFork("testfile.txt", make([]byte, 8), "", ""),
FlatFileDataForkHeader: FlatFileDataForkHeader{
ForkType: [4]byte{0x4d, 0x41, 0x43, 0x52}, // DATA
CompressionType: [4]byte{0, 0, 0, 0},
res = append(res, cc.NewReply(t,
NewField(fieldFileName, fileName),
- NewField(fieldFileTypeString, ffo.FlatFileInformationFork.TypeSignature),
+ NewField(fieldFileTypeString, ffo.FlatFileInformationFork.friendlyType()),
NewField(fieldFileCreatorString, ffo.FlatFileInformationFork.CreatorSignature),
NewField(fieldFileComment, ffo.FlatFileInformationFork.Comment),
NewField(fieldFileType, ffo.FlatFileInformationFork.TypeSignature),
ErrorCode: []byte{0, 0, 0, 0},
Fields: []Field{
NewField(fieldFileName, []byte("testfile.txt")),
- NewField(fieldFileTypeString, []byte("TEXT")),
+ NewField(fieldFileTypeString, []byte("Text File")),
NewField(fieldFileCreatorString, []byte("ttxt")),
NewField(fieldFileComment, []byte{}),
NewField(fieldFileType, []byte("TEXT")),
testFile := flattenedFileObject{
FlatFileHeader: NewFlatFileHeader(),
FlatFileInformationForkHeader: FlatFileInformationForkHeader{},
- FlatFileInformationFork: NewFlatFileInformationFork("testfile.txt", make([]byte, 8)),
+ FlatFileInformationFork: NewFlatFileInformationFork("testfile.txt", make([]byte, 8), "TEXT", "TEXT"),
FlatFileDataForkHeader: FlatFileDataForkHeader{
ForkType: [4]byte{0x4d, 0x41, 0x43, 0x52}, // DATA
CompressionType: [4]byte{0, 0, 0, 0},