aboutsummaryrefslogtreecommitdiff
path: root/packfile/ingest/record_content.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-10 14:07:54 +0800
committerGravatar Runxi Yu2026-03-10 14:07:54 +0800
commitc2cb06aa23a1769a0d84756acccf1ac1358f61ef (patch)
tree86d991b67542dd8e8509a74c832b749ccf948342 /packfile/ingest/record_content.go
parentcommitgraph: Move out of format/ (diff)
signatureNo signature
*: format/pack -> packfile; format/delta -> delta; delete format
Diffstat (limited to 'packfile/ingest/record_content.go')
-rw-r--r--packfile/ingest/record_content.go30
1 files changed, 30 insertions, 0 deletions
diff --git a/packfile/ingest/record_content.go b/packfile/ingest/record_content.go
new file mode 100644
index 00000000..05972b22
--- /dev/null
+++ b/packfile/ingest/record_content.go
@@ -0,0 +1,30 @@
+package ingest
+
+import (
+ "fmt"
+
+ "codeberg.org/lindenii/furgit/objecttype"
+ packfmt "codeberg.org/lindenii/furgit/packfile"
+)
+
+// readBaseRecordContent reads canonical base content for one non-delta record.
+func readBaseRecordContent(state *ingestState, idx int) (objecttype.Type, []byte, error) {
+ record := state.records[idx]
+ if !packfmt.IsBaseObjectType(record.packedType) {
+ return objecttype.TypeInvalid, nil, fmt.Errorf("packfile/ingest: record %d is not a base object", idx)
+ }
+
+ content, err := inflateRecordPayload(state, idx)
+ if err != nil {
+ return objecttype.TypeInvalid, nil, err
+ }
+
+ if int64(len(content)) != record.declaredSize {
+ return objecttype.TypeInvalid, nil, &MalformedPackEntryError{
+ Offset: record.offset,
+ Reason: fmt.Sprintf("base content size mismatch got %d want %d", len(content), record.declaredSize),
+ }
+ }
+
+ return record.packedType, content, nil
+}