aboutsummaryrefslogtreecommitdiff
path: root/refstore/files/update_verify_refnames.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-23 03:25:44 +0000
committerGravatar Runxi Yu2026-03-23 03:27:52 +0000
commit4a796e64ac576d6a3e3f2fe6174c4aa476ea0c5c (patch)
tree44d72a20076ceab0981d0b553693d26ca36cc0be /refstore/files/update_verify_refnames.go
parentreceivepack: Lifecycle/ownership docs (diff)
signatureNo signature
refstore: Improve interfaces, errors, and make batch work v0.1.92
Diffstat (limited to 'refstore/files/update_verify_refnames.go')
-rw-r--r--refstore/files/update_verify_refnames.go41
1 files changed, 41 insertions, 0 deletions
diff --git a/refstore/files/update_verify_refnames.go b/refstore/files/update_verify_refnames.go
new file mode 100644
index 00000000..12d67c5f
--- /dev/null
+++ b/refstore/files/update_verify_refnames.go
@@ -0,0 +1,41 @@
+package files
+
+import (
+ "strings"
+
+ "codeberg.org/lindenii/furgit/refstore"
+)
+
+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+"/")
+}