diff options
| author | 2026-03-07 18:09:20 +0800 | |
|---|---|---|
| committer | 2026-03-07 18:17:54 +0800 | |
| commit | e667c3c52a535ee67fe895bb0240fbad6e920087 (patch) | |
| tree | 0815f7cc9b2c4a06d00722bce4c3ac57c515288b /refstore/files/transaction_write_loose.go | |
| parent | receivepack: Connect protocol with service (diff) | |
refstore/files: Accept timeout instead of reading from config
And split things up again.
Diffstat (limited to 'refstore/files/transaction_write_loose.go')
| -rw-r--r-- | refstore/files/transaction_write_loose.go | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/refstore/files/transaction_write_loose.go b/refstore/files/transaction_write_loose.go new file mode 100644 index 00000000..b2a0e5d6 --- /dev/null +++ b/refstore/files/transaction_write_loose.go @@ -0,0 +1,59 @@ +package files + +import ( + "fmt" + "os" + "path" + "strings" +) + +func (tx *Transaction) writeLoose(item preparedTxOp) error { + root := tx.store.rootFor(item.target.loc.root) + lockName := item.target.loc.path + ".lock" + + lock, err := root.OpenFile(lockName, os.O_WRONLY|os.O_TRUNC, 0o644) + if err != nil { + return err + } + + var content string + + switch item.op.kind { + case txCreate, txUpdate: + content = item.op.newID.String() + "\n" + case txCreateSymbolic, txUpdateSymbolic: + content = "ref: " + strings.TrimSpace(item.op.newTarget) + "\n" + case txDelete, txVerify, txDeleteSymbolic, txVerifySymbolic: + default: + _ = lock.Close() + + return fmt.Errorf("refstore/files: unsupported write operation %d", item.op.kind) + } + + _, err = lock.WriteString(content) + if err != nil { + _ = lock.Close() + + return err + } + + err = lock.Close() + if err != nil { + return err + } + + dir := path.Dir(item.target.loc.path) + if dir != "." { + err = root.MkdirAll(dir, 0o755) + if err != nil { + return err + } + } + + err = tx.removeEmptyDirTree(item.target.loc) + if err != nil { + return err + } + + return root.Rename(lockName, item.target.loc.path) +} |
