From 1aa5cad4c8d6455eeb1f10893549e18bcca11996 Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Wed, 25 Mar 2026 19:33:32 +0000 Subject: object/fetch: Rename from object/resolve --- object/fetch/treefs_readfile.go | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 object/fetch/treefs_readfile.go (limited to 'object/fetch/treefs_readfile.go') diff --git a/object/fetch/treefs_readfile.go b/object/fetch/treefs_readfile.go new file mode 100644 index 00000000..d3671f07 --- /dev/null +++ b/object/fetch/treefs_readfile.go @@ -0,0 +1,40 @@ +package fetch + +import ( + "fmt" + "io" + + "codeberg.org/lindenii/furgit/object/tree" +) + +// ReadFile reads the blob contents at name. +// +// Directories and gitlink entries are not readable through TreeFS. +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 == tree.FileModeGitlink { + return nil, treeFSPathError(treeFSOpReadFile, name, fmt.Errorf("object/fetch: 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 +} -- cgit v1.3.1-10-gc9f91