diff options
| author | 2026-03-07 22:38:17 +0800 | |
|---|---|---|
| committer | 2026-03-07 22:38:17 +0800 | |
| commit | 0fb1520c3119ed6aedc5cb25098c0fd0b4cacf90 (patch) | |
| tree | e02e31a56a4893f9a0397158811e50cae91dc012 /receivepack/service/quarantine_objects.go | |
| parent | *: Add some package-level doc comments (diff) | |
*: Package sorting and updates
Diffstat (limited to 'receivepack/service/quarantine_objects.go')
| -rw-r--r-- | receivepack/service/quarantine_objects.go | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/receivepack/service/quarantine_objects.go b/receivepack/service/quarantine_objects.go new file mode 100644 index 00000000..69e07a1d --- /dev/null +++ b/receivepack/service/quarantine_objects.go @@ -0,0 +1,50 @@ +package service + +import ( + "os" + + "codeberg.org/lindenii/furgit/objectstore" + "codeberg.org/lindenii/furgit/objectstore/loose" + "codeberg.org/lindenii/furgit/objectstore/memory" + objectmix "codeberg.org/lindenii/furgit/objectstore/mix" + "codeberg.org/lindenii/furgit/objectstore/packed" +) + +func (service *Service) openQuarantinedObjects(quarantineName string) (objectstore.Store, error) { + if quarantineName == "" { + return memory.New(service.opts.Algorithm), nil + } + + looseRoot, err := service.opts.ObjectsRoot.OpenRoot(quarantineName) + if err != nil { + return nil, err + } + + looseStore, err := loose.New(looseRoot, service.opts.Algorithm) + if err != nil { + _ = looseRoot.Close() + + return nil, err + } + + packRoot, err := looseRoot.OpenRoot("pack") + if err == nil { + packedStore, packedErr := packed.New(packRoot, service.opts.Algorithm) + if packedErr != nil { + _ = packRoot.Close() + _ = looseStore.Close() + + return nil, packedErr + } + + return objectmix.New(looseStore, packedStore), nil + } + + if !os.IsNotExist(err) { + _ = looseStore.Close() + + return nil, err + } + + return looseStore, nil +} |
