aboutsummaryrefslogtreecommitdiff
path: root/refstore/files/transaction_direct_read.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/transaction_direct_read.go
parentreceivepack: Lifecycle/ownership docs (diff)
refstore: Improve interfaces, errors, and make batch work v0.1.92
Diffstat (limited to 'refstore/files/transaction_direct_read.go')
-rw-r--r--refstore/files/transaction_direct_read.go76
1 files changed, 0 insertions, 76 deletions
diff --git a/refstore/files/transaction_direct_read.go b/refstore/files/transaction_direct_read.go
deleted file mode 100644
index 4da6a499..00000000
--- a/refstore/files/transaction_direct_read.go
+++ /dev/null
@@ -1,76 +0,0 @@
-package files
-
-import (
- "errors"
- "fmt"
-
- "codeberg.org/lindenii/furgit/ref"
- "codeberg.org/lindenii/furgit/ref/refname"
- "codeberg.org/lindenii/furgit/refstore"
-)
-
-func (tx *Transaction) directRead(name string) (directRef, error) {
- loc := tx.store.loosePath(name)
- hasPacked := false
-
- if loc.root == rootCommon && refname.ParseWorktree(name).Type == refname.WorktreeShared {
- packed, packedErr := tx.store.readPackedRefs()
- if packedErr != nil {
- return directRef{}, packedErr
- }
-
- _, hasPacked = packed.byName[name]
- }
-
- loose, err := tx.store.readLooseRef(name)
- if err == nil {
- switch loose := loose.(type) {
- case ref.Detached:
- return directRef{
- kind: directDetached,
- name: name,
- id: loose.ID,
- isLoose: true,
- isPacked: hasPacked,
- }, nil
- case ref.Symbolic:
- return directRef{
- kind: directSymbolic,
- name: name,
- target: loose.Target,
- isLoose: true,
- isPacked: hasPacked,
- }, nil
- default:
- return directRef{}, fmt.Errorf("refstore/files: unsupported reference type %T", loose)
- }
- }
-
- if !errors.Is(err, refstore.ErrReferenceNotFound) {
- info, statErr := tx.store.rootFor(loc.root).Stat(loc.path)
- if statErr != nil || !info.IsDir() {
- return directRef{}, err
- }
- }
-
- if hasPacked {
- packed, packedErr := tx.store.readPackedRefs()
- if packedErr != nil {
- return directRef{}, packedErr
- }
-
- detached := packed.byName[name]
-
- return directRef{
- kind: directDetached,
- name: name,
- id: detached.ID,
- isPacked: true,
- }, nil
- }
-
- return directRef{
- kind: directMissing,
- name: name,
- }, nil
-}