aboutsummaryrefslogtreecommitdiff
path: root/ref/store/files/update_verify_refnames.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/update_verify_refnames.go
parent*: objectstore -> object/store (diff)
signatureNo signature
*: refstore -> ref/store
Diffstat (limited to 'ref/store/files/update_verify_refnames.go')
-rw-r--r--ref/store/files/update_verify_refnames.go41
1 files changed, 41 insertions, 0 deletions
diff --git a/ref/store/files/update_verify_refnames.go b/ref/store/files/update_verify_refnames.go
new file mode 100644
index 00000000..308a9868
--- /dev/null
+++ b/ref/store/files/update_verify_refnames.go
@@ -0,0 +1,41 @@
+package files
+
+import (
+ "strings"
+
+ "codeberg.org/lindenii/furgit/ref/store"
+)
+
+func verifyRefnameAvailable(name string, existing map[string]struct{}, writes []string, deleted map[string]struct{}) error {
+ for existingName := range existing {
+ if existingName == name {
+ continue
+ }
+
+ if _, skip := deleted[existingName]; skip {
+ continue
+ }
+
+ if refnamesConflict(name, existingName) {
+ return wrapUpdateError(name, &refstore.NameConflictError{Other: existingName})
+ }
+ }
+
+ for _, other := range writes {
+ if other == name {
+ continue
+ }
+
+ if refnamesConflict(name, other) {
+ return wrapUpdateError(name, &refstore.NameConflictError{Other: other})
+ }
+ }
+
+ return nil
+}
+
+func refnamesConflict(left, right string) bool {
+ return left == right ||
+ strings.HasPrefix(left, right+"/") ||
+ strings.HasPrefix(right, left+"/")
+}