diff options
| author | 2026-03-25 14:31:16 +0000 | |
|---|---|---|
| committer | 2026-03-25 14:31:16 +0000 | |
| commit | 48ff647cf4a8bb8f23fcd6b8616f56a8ef72b980 (patch) | |
| tree | ae199c38042adaa544d5f7d31351661d5831381e /ref/store/files/update_cleanup.go | |
| parent | *: objectstore -> object/store (diff) | |
| signature | No signature | |
*: refstore -> ref/store
Diffstat (limited to 'ref/store/files/update_cleanup.go')
| -rw-r--r-- | ref/store/files/update_cleanup.go | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/ref/store/files/update_cleanup.go b/ref/store/files/update_cleanup.go new file mode 100644 index 00000000..5df2d967 --- /dev/null +++ b/ref/store/files/update_cleanup.go @@ -0,0 +1,39 @@ +package files + +import ( + "errors" + "os" + "slices" +) + +func (executor *refUpdateExecutor) cleanupPreparedUpdates(prepared []preparedUpdate) error { + var firstErr error + + lockNames := make([]string, 0, len(prepared)+1) + for _, item := range prepared { + lockNames = append(lockNames, updateTargetKey(item.target.loc)) + } + + lockNames = append(lockNames, updateTargetKey(refPath{root: rootCommon, path: "packed-refs"})) + slices.Sort(lockNames) + lockNames = slices.Compact(lockNames) + + for _, lockKey := range lockNames { + lockPath := refPathFromKey(lockKey) + lockName := lockPath.path + ".lock" + root := executor.store.rootFor(lockPath.root) + + err := root.Remove(lockName) + if err == nil || errors.Is(err, os.ErrNotExist) { + executor.tryRemoveEmptyParentPaths(lockPath.root, lockName) + + continue + } + + if firstErr == nil { + firstErr = err + } + } + + return firstErr +} |
