aboutsummaryrefslogtreecommitdiff
path: root/ref/store/files/read_resolve.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-25 14:31:16 +0000
committerGravatar Runxi Yu2026-03-25 14:31:16 +0000
commit48ff647cf4a8bb8f23fcd6b8616f56a8ef72b980 (patch)
treeae199c38042adaa544d5f7d31351661d5831381e /ref/store/files/read_resolve.go
parent*: objectstore -> object/store (diff)
signatureNo signature
*: refstore -> ref/store
Diffstat (limited to 'ref/store/files/read_resolve.go')
-rw-r--r--ref/store/files/read_resolve.go41
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
+}