From 947bf81a33c6e4e5d21c8b36f9317fe00b84f6ae Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Sun, 24 May 2026 13:41:34 +0000 Subject: ref/store/memory: Simple memory-backed ref store --- ref/store/memory/ref.go | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 ref/store/memory/ref.go (limited to 'ref/store/memory/ref.go') 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 +} -- cgit v1.3.1-10-gc9f91