diff options
| author | 2026-03-25 14:31:16 +0000 | |
|---|---|---|
| committer | 2026-03-25 14:31:16 +0000 | |
| commit | 48ff647cf4a8bb8f23fcd6b8616f56a8ef72b980 (patch) | |
| tree | ae199c38042adaa544d5f7d31351661d5831381e /ref/store/files/read_resolve.go | |
| parent | *: objectstore -> object/store (diff) | |
| signature | No signature | |
*: refstore -> ref/store
Diffstat (limited to 'ref/store/files/read_resolve.go')
| -rw-r--r-- | ref/store/files/read_resolve.go | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/ref/store/files/read_resolve.go b/ref/store/files/read_resolve.go new file mode 100644 index 00000000..bba6c7e7 --- /dev/null +++ b/ref/store/files/read_resolve.go @@ -0,0 +1,41 @@ +package files + +import ( + "errors" + + "codeberg.org/lindenii/furgit/ref" + "codeberg.org/lindenii/furgit/ref/store" +) + +// Resolve resolves one reference name from the files store visible namespace. +func (store *Store) Resolve(name string) (ref.Ref, error) { //nolint:ireturn + if name == "" { + return nil, refstore.ErrReferenceNotFound + } + + resolved, err := store.readLooseRef(name) + if err == nil { + return resolved, nil + } + + if !errors.Is(err, refstore.ErrReferenceNotFound) { + refPath := store.loosePath(name) + + info, statErr := store.rootFor(refPath.root).Stat(refPath.path) + if statErr != nil || !info.IsDir() { + return nil, err + } + } + + packed, packedErr := store.readPackedRefs() + if packedErr != nil { + return nil, packedErr + } + + detached, ok := packed.byName[name] + if !ok { + return nil, refstore.ErrReferenceNotFound + } + + return detached, nil +} |
