diff options
| author | 2026-03-06 11:26:21 +0800 | |
|---|---|---|
| committer | 2026-03-06 11:30:56 +0800 | |
| commit | 75c7147c6afcb64a7c8bfedb08f1613c5011ff71 (patch) | |
| tree | d348e7f4eeec5a905970a7ff14c5c2dd492d944a /objectstore/packed/close.go | |
| parent | format/commitgraph: Split files (diff) | |
| signature | No signature | |
objectstore/packed: Split files
Diffstat (limited to 'objectstore/packed/close.go')
| -rw-r--r-- | objectstore/packed/close.go | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/objectstore/packed/close.go b/objectstore/packed/close.go new file mode 100644 index 00000000..2bb98232 --- /dev/null +++ b/objectstore/packed/close.go @@ -0,0 +1,47 @@ +package packed + +// Close releases mapped pack/index resources associated with the store. +func (store *Store) Close() error { + store.stateMu.Lock() + + if store.closed { + store.stateMu.Unlock() + + return nil + } + + store.closed = true + root := store.root + packs := store.packs + store.stateMu.Unlock() + store.idxMu.RLock() + indexes := store.idxByPack + store.idxMu.RUnlock() + + var closeErr error + + for _, pack := range packs { + err := pack.close() + if err != nil && closeErr == nil { + closeErr = err + } + } + + for _, index := range indexes { + err := index.close() + if err != nil && closeErr == nil { + closeErr = err + } + } + + store.cacheMu.Lock() + store.deltaCache.clear() + store.cacheMu.Unlock() + + err := root.Close() + if err != nil && closeErr == nil { + closeErr = err + } + + return closeErr +} |
