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_readfile.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_readfile.go')
| -rw-r--r-- | object/resolve/treefs_readfile.go | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/object/resolve/treefs_readfile.go b/object/resolve/treefs_readfile.go new file mode 100644 index 00000000..72af931c --- /dev/null +++ b/object/resolve/treefs_readfile.go @@ -0,0 +1,37 @@ +package resolve + +import ( + "fmt" + "io" + + "codeberg.org/lindenii/furgit/object" +) + +func (treeFS *TreeFS) ReadFile(name string) ([]byte, error) { + entry, err := treeFS.resolvePath(treeFSOpReadFile, name) + if err != nil { + return nil, err + } + + if entry.isDir() { + return nil, treeFSPathError(treeFSOpReadFile, name, fmt.Errorf("is a directory")) + } + + if entry.mode == object.FileModeGitlink { + return nil, treeFSPathError(treeFSOpReadFile, name, fmt.Errorf("object/resolve: gitlink entries are not readable as files")) + } + + reader, _, err := treeFS.resolver.ExactBlobReader(entry.objectID) + if err != nil { + return nil, treeFSPathError(treeFSOpReadFile, name, err) + } + + defer func() { _ = reader.Close() }() + + data, err := io.ReadAll(reader) + if err != nil { + return nil, treeFSPathError(treeFSOpReadFile, name, err) + } + + return data, nil +} |
