aboutsummaryrefslogtreecommitdiff
path: root/object/store/loose/read_header.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-25 14:30:31 +0000
committerGravatar Runxi Yu2026-03-25 14:30:31 +0000
commitbfa0a3f5f18b752a6ebd3d5b37411c6871f7bb17 (patch)
tree8ee2479273e2b34d284c30703c2be48efe197556 /object/store/loose/read_header.go
parent*: Resort import order (diff)
signatureNo signature
*: objectstore -> object/store
Diffstat (limited to 'object/store/loose/read_header.go')
-rw-r--r--object/store/loose/read_header.go37
1 files changed, 37 insertions, 0 deletions
diff --git a/object/store/loose/read_header.go b/object/store/loose/read_header.go
new file mode 100644
index 00000000..37bf40de
--- /dev/null
+++ b/object/store/loose/read_header.go
@@ -0,0 +1,37 @@
+package loose
+
+import (
+ "bufio"
+
+ "codeberg.org/lindenii/furgit/internal/compress/zlib"
+ objectid "codeberg.org/lindenii/furgit/object/id"
+ objecttype "codeberg.org/lindenii/furgit/object/type"
+)
+
+// ReadHeader reads an object's type and declared content length.
+//
+// It parses only enough of the zlib-decoded object to recover the object
+// header. It does not verify that the remaining object content is readable and
+// does not verify the zlib Adler-32 trailer.
+func (store *Store) ReadHeader(id objectid.ObjectID) (objecttype.Type, int64, error) {
+ file, err := store.openObject(id)
+ if err != nil {
+ return objecttype.TypeInvalid, 0, err
+ }
+
+ defer func() { _ = file.Close() }()
+
+ zr, err := zlib.NewReader(file)
+ if err != nil {
+ return objecttype.TypeInvalid, 0, err
+ }
+
+ defer func() { _ = zr.Close() }()
+
+ _, ty, size, err := readHeader(bufio.NewReader(zr))
+ if err != nil {
+ return objecttype.TypeInvalid, 0, err
+ }
+
+ return ty, size, nil
+}