X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/c5d9af5aa4d9fb20316be45ab1b775bcf61bcad5..c62f0b470f0ce33d5f52897f2cae7fd355f04b80:/hotline/file_path.go?ds=sidebyside diff --git a/hotline/file_path.go b/hotline/file_path.go index 733dfaa..2e2e085 100644 --- a/hotline/file_path.go +++ b/hotline/file_path.go @@ -1,8 +1,10 @@ package hotline import ( + "bytes" "encoding/binary" - "strings" + "errors" + "path" ) const pathSeparator = "/" // File path separator TODO: make configurable to support Windows @@ -24,12 +26,22 @@ func NewFilePathItem(b []byte) FilePathItem { } type FilePath struct { - ItemCount []byte + ItemCount [2]byte Items []FilePathItem } +const minFilePathLen = 2 func (fp *FilePath) UnmarshalBinary(b []byte) error { - fp.ItemCount = b[0:2] + if b == nil { + return nil + } + if len(b) < minFilePathLen { + return errors.New("insufficient bytes") + } + err := binary.Read(bytes.NewReader(b[0:2]), binary.BigEndian, &fp.ItemCount) + if err != nil { + return err + } pathData := b[2:] for i := uint16(0); i < fp.Len(); i++ { @@ -42,15 +54,16 @@ func (fp *FilePath) UnmarshalBinary(b []byte) error { } func (fp *FilePath) Len() uint16 { - return binary.BigEndian.Uint16(fp.ItemCount) + return binary.BigEndian.Uint16(fp.ItemCount[:]) } func (fp *FilePath) String() string { - var out []string + out := []string{"/"} for _, i := range fp.Items { out = append(out, string(i.Name)) } - return strings.Join(out, pathSeparator) + + return path.Join(out...) } func ReadFilePath(filePathFieldData []byte) string { @@ -61,3 +74,21 @@ func ReadFilePath(filePathFieldData []byte) string { } return fp.String() } + +func readPath(fileRoot string, filePath, fileName []byte) (fullPath string, err error) { + var fp FilePath + if filePath != nil { + if err = fp.UnmarshalBinary(filePath); err != nil { + return "", err + } + } + + fullPath = path.Join( + "/", + fileRoot, + fp.String(), + path.Join("/", string(fileName)), + ) + + return fullPath, nil +}