diff options
| author | 2026-03-23 06:06:53 +0000 | |
|---|---|---|
| committer | 2026-03-23 06:06:53 +0000 | |
| commit | 8d555a5aae15017c3c3332605bdf4fd33e20aaa0 (patch) | |
| tree | 0858e752b5a60e760cb0548e1faba87cd64ded24 /object/resolve/treefs_entry.go | |
| parent | refstore/files: Pretty big logical restructure ish lint fix for batch Apply (diff) | |
| signature | No signature | |
object/resolve: Add TreeFS v0.1.95
Diffstat (limited to 'object/resolve/treefs_entry.go')
| -rw-r--r-- | object/resolve/treefs_entry.go | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/object/resolve/treefs_entry.go b/object/resolve/treefs_entry.go new file mode 100644 index 00000000..402b47d2 --- /dev/null +++ b/object/resolve/treefs_entry.go @@ -0,0 +1,82 @@ +package resolve + +import ( + "fmt" + "io/fs" + "strings" + + "codeberg.org/lindenii/furgit/object" + "codeberg.org/lindenii/furgit/objectid" +) + +func (treeFS *TreeFS) resolvePath(op treeFSOp, name string) (treeEntryValue, error) { + if !treeFSValidPath(name) { + return treeEntryValue{}, treeFSPathError(op, name, fs.ErrInvalid) + } + + if name == "." { + return treeEntryValue{ + name: ".", + mode: object.FileModeDir, + treeID: treeFS.rootTree, + treeEntry: treeFS.rootEntry, + }, nil + } + + entry, err := treeFS.resolver.Path(treeFS.rootTree, treeFSSplitPath(name)) + if err != nil { + return treeEntryValue{}, treeFS.pathResolveError(op, name, err) + } + + return treeEntryValue{ + name: string(entry.Name), + mode: entry.Mode, + objectID: entry.ID, + treeEntry: &entry, + }, nil +} + +func (treeFS *TreeFS) pathResolveError(op treeFSOp, name string, err error) error { + if err != nil && strings.Contains(err.Error(), "not found") { + return treeFSPathError(op, name, fs.ErrNotExist) + } + + if err != nil && strings.Contains(err.Error(), "is not a tree") { + return treeFSPathError(op, name, fs.ErrInvalid) + } + + return treeFSPathError(op, name, err) +} + +type treeEntryValue struct { + name string + mode object.FileMode + objectID objectid.ObjectID + treeID objectid.ObjectID + treeEntry *object.TreeEntry +} + +func (entry treeEntryValue) isDir() bool { + return entry.mode == object.FileModeDir +} + +func (entry treeEntryValue) blobSize(resolve *Resolver) (int64, error) { + _, size, err := resolve.store.ReadHeader(entry.objectID) + if err != nil { + return 0, err + } + + return size, nil +} + +func (entry treeEntryValue) subtreeID() (objectid.ObjectID, error) { + if entry.name == "." { + return entry.treeID, nil + } + + if entry.mode != object.FileModeDir { + return objectid.ObjectID{}, fmt.Errorf("object/resolve: path %q is not a tree", entry.name) + } + + return entry.objectID, nil +} |
