aboutsummaryrefslogtreecommitdiff
path: root/ref/store/memory/ref.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-05-24 13:41:34 +0000
committerGravatar Runxi Yu2026-05-24 14:12:35 +0000
commit947bf81a33c6e4e5d21c8b36f9317fe00b84f6ae (patch)
tree67824655ef9dbf2d941dae06d59ea29a1e32d458 /ref/store/memory/ref.go
parentREADME: Update (diff)
signatureNo signature
ref/store/memory: Simple memory-backed ref store v0.1.175
Diffstat (limited to 'ref/store/memory/ref.go')
-rw-r--r--ref/store/memory/ref.go45
1 files changed, 45 insertions, 0 deletions
diff --git a/ref/store/memory/ref.go b/ref/store/memory/ref.go
new file mode 100644
index 00000000..67d9268f
--- /dev/null
+++ b/ref/store/memory/ref.go
@@ -0,0 +1,45 @@
+package memory
+
+import objectid "codeberg.org/lindenii/furgit/object/id"
+
+// Because the public one includes the ref's name/identity.
+
+type storedKind uint8
+
+const (
+ storedMissing storedKind = iota
+ storedDetached
+ storedSymbolic
+)
+
+// Missing is obviously not the best design
+// but it does make it easier to operate on internally.
+// Might make a tagged union wrapper, though...
+// Or might just make a wrapper struct that has an "ok" bool.
+
+type storedRef struct {
+ kind storedKind
+ id objectid.ObjectID
+ target string
+ peeled *objectid.ObjectID
+}
+
+func cloneStoredRef(stored storedRef) storedRef {
+ if stored.peeled == nil {
+ return stored
+ }
+
+ peeled := *stored.peeled
+ stored.peeled = &peeled
+
+ return stored
+}
+
+func cloneRefs(refs map[string]storedRef) map[string]storedRef {
+ cloned := make(map[string]storedRef, len(refs))
+ for name, stored := range refs {
+ cloned[name] = cloneStoredRef(stored)
+ }
+
+ return cloned
+}