aboutsummaryrefslogtreecommitdiff
path: root/objectstore/packed
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-02-21 15:29:40 +0800
committerGravatar Runxi Yu2026-02-21 15:29:40 +0800
commit673902b14458f32fbf47efa3757279872bdfcb7e (patch)
treecdcae5d8c7ee01e4931a306931fc79c01c1ea406 /objectstore/packed
parentrepository: Add passthrough ReadStored*; add ref convenience funcs (diff)
signatureNo signature
repository, {ref,object}store: Make stores own their roots
Diffstat (limited to 'objectstore/packed')
-rw-r--r--objectstore/packed/store.go13
1 files changed, 7 insertions, 6 deletions
diff --git a/objectstore/packed/store.go b/objectstore/packed/store.go
index fc2e1c10..ace11782 100644
--- a/objectstore/packed/store.go
+++ b/objectstore/packed/store.go
@@ -12,7 +12,7 @@ import (
// Store reads Git objects from pack/index files under an objects/pack root.
//
-// Store does not own root. Callers are responsible for closing root.
+// Store owns root and closes it in Close.
type Store struct {
// root is the objects/pack capability used for all file access.
root *os.Root
@@ -65,10 +65,9 @@ func (store *Store) Close() error {
return nil
}
store.closed = true
+ root := store.root
packs := store.packs
- store.packs = make(map[string]*packFile)
indexes := store.indexes
- store.indexes = nil
store.stateMu.Unlock()
var closeErr error
@@ -86,10 +85,12 @@ func (store *Store) Close() error {
}
}
store.cacheMu.Lock()
- if store.deltaCache != nil {
- store.deltaCache.clear()
- }
+ store.deltaCache.clear()
store.cacheMu.Unlock()
+
+ if err := root.Close(); err != nil && closeErr == nil {
+ closeErr = err
+ }
return closeErr
}