aboutsummaryrefslogtreecommitdiff
path: root/object/store/packed/read_bytes.go
diff options
context:
space:
mode:
Diffstat (limited to 'object/store/packed/read_bytes.go')
-rw-r--r--object/store/packed/read_bytes.go38
1 files changed, 38 insertions, 0 deletions
diff --git a/object/store/packed/read_bytes.go b/object/store/packed/read_bytes.go
new file mode 100644
index 00000000..333cfaae
--- /dev/null
+++ b/object/store/packed/read_bytes.go
@@ -0,0 +1,38 @@
+package packed
+
+import (
+ "fmt"
+
+ objectheader "codeberg.org/lindenii/furgit/object/header"
+ objectid "codeberg.org/lindenii/furgit/object/id"
+ objecttype "codeberg.org/lindenii/furgit/object/type"
+)
+
+// ReadBytesContent reads an object's type and content bytes.
+func (store *Store) ReadBytesContent(id objectid.ObjectID) (objecttype.Type, []byte, error) {
+ loc, err := store.lookup(id)
+ if err != nil {
+ return objecttype.TypeInvalid, nil, err
+ }
+
+ return store.deltaResolveContent(loc)
+}
+
+// ReadBytesFull reads a full serialized object as "type size\0content".
+func (store *Store) ReadBytesFull(id objectid.ObjectID) ([]byte, error) {
+ ty, content, err := store.ReadBytesContent(id)
+ if err != nil {
+ return nil, err
+ }
+
+ header, ok := objectheader.Encode(ty, int64(len(content)))
+ if !ok {
+ return nil, fmt.Errorf("objectstore/packed: failed to encode object header for type %d", ty)
+ }
+
+ out := make([]byte, len(header)+len(content))
+ copy(out, header)
+ copy(out[len(header):], content)
+
+ return out, nil
+}