aboutsummaryrefslogtreecommitdiff
path: root/object/store/packed/read_header_resolve.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-25 14:34:50 +0000
committerGravatar Runxi Yu2026-03-25 14:34:50 +0000
commite4a7aa0742f5070299d37e8421c99d67f0af3f90 (patch)
tree36d89781476a92e61280c5ff232a2773e4092c0e /object/store/packed/read_header_resolve.go
parent*: delta -> packfile/delta (diff)
signatureNo signature
*: object/store -> object/storer v0.1.107
Diffstat (limited to 'object/store/packed/read_header_resolve.go')
-rw-r--r--object/store/packed/read_header_resolve.go66
1 files changed, 0 insertions, 66 deletions
diff --git a/object/store/packed/read_header_resolve.go b/object/store/packed/read_header_resolve.go
deleted file mode 100644
index 6fee720a..00000000
--- a/object/store/packed/read_header_resolve.go
+++ /dev/null
@@ -1,66 +0,0 @@
-package packed
-
-import (
- "fmt"
-
- objecttype "codeberg.org/lindenii/furgit/object/type"
- packfmt "codeberg.org/lindenii/furgit/packfile"
-)
-
-// resolveHeaderAt resolves one object's canonical type and declared content size.
-func (store *Store) resolveHeaderAt(start location) (objecttype.Type, int64, error) {
- visited := make(map[location]struct{})
- current := start
- declaredSize := int64(-1)
-
- for {
- if _, ok := visited[current]; ok {
- return objecttype.TypeInvalid, 0, fmt.Errorf("objectstore/packed: delta cycle while resolving object header")
- }
-
- visited[current] = struct{}{}
-
- pack, meta, err := store.entryMetaAt(current)
- if err != nil {
- return objecttype.TypeInvalid, 0, err
- }
-
- if declaredSize < 0 {
- if packfmt.IsBaseObjectType(meta.ty) {
- declaredSize = meta.size
- } else {
- size, err := deltaDeclaredSizeAt(pack, meta.dataOffset)
- if err != nil {
- return objecttype.TypeInvalid, 0, err
- }
-
- declaredSize = size
- }
- }
-
- if packfmt.IsBaseObjectType(meta.ty) {
- return meta.ty, declaredSize, nil
- }
-
- switch meta.ty {
- case objecttype.TypeRefDelta:
- next, err := store.lookup(meta.baseRefID)
- if err != nil {
- return objecttype.TypeInvalid, 0, err
- }
-
- current = next
- case objecttype.TypeOfsDelta:
- current = location{
- packName: current.packName,
- offset: meta.baseOfs,
- }
- case objecttype.TypeCommit, objecttype.TypeTree, objecttype.TypeBlob, objecttype.TypeTag:
- return objecttype.TypeInvalid, 0, fmt.Errorf("objectstore/packed: internal invariant violation for base type %d", meta.ty)
- case objecttype.TypeInvalid, objecttype.TypeFuture:
- return objecttype.TypeInvalid, 0, fmt.Errorf("objectstore/packed: unsupported pack type %d", meta.ty)
- default:
- return objecttype.TypeInvalid, 0, fmt.Errorf("objectstore/packed: unsupported pack type %d", meta.ty)
- }
- }
-}