diff options
| author | 2026-03-25 14:31:16 +0000 | |
|---|---|---|
| committer | 2026-03-25 14:31:16 +0000 | |
| commit | 48ff647cf4a8bb8f23fcd6b8616f56a8ef72b980 (patch) | |
| tree | ae199c38042adaa544d5f7d31351661d5831381e /refstore/files/read_resolve_fully.go | |
| parent | *: objectstore -> object/store (diff) | |
| signature | No signature | |
*: refstore -> ref/store
Diffstat (limited to 'refstore/files/read_resolve_fully.go')
| -rw-r--r-- | refstore/files/read_resolve_fully.go | 42 |
1 files changed, 0 insertions, 42 deletions
diff --git a/refstore/files/read_resolve_fully.go b/refstore/files/read_resolve_fully.go deleted file mode 100644 index de58eb6d..00000000 --- a/refstore/files/read_resolve_fully.go +++ /dev/null @@ -1,42 +0,0 @@ -package files - -import ( - "fmt" - "strings" - - "codeberg.org/lindenii/furgit/ref" -) - -// ResolveToDetached resolves symbolic references through the visible files store -// namespace until one detached reference is reached. -func (store *Store) ResolveToDetached(name string) (ref.Detached, error) { - cur := name - seen := make(map[string]struct{}) - - for { - if _, ok := seen[cur]; ok { - return ref.Detached{}, fmt.Errorf("refstore/files: symbolic reference cycle at %q", cur) - } - - seen[cur] = struct{}{} - - resolved, err := store.Resolve(cur) - if err != nil { - return ref.Detached{}, err - } - - switch resolved := resolved.(type) { - case ref.Detached: - return resolved, nil - case ref.Symbolic: - target := strings.TrimSpace(resolved.Target) - if target == "" { - return ref.Detached{}, fmt.Errorf("refstore/files: symbolic reference %q has empty target", resolved.Name()) - } - - cur = target - default: - return ref.Detached{}, fmt.Errorf("refstore/files: unsupported reference type %T", resolved) - } - } -} |
