From 7d9c128ce04875f970c78673500c0a492000398f Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Wed, 25 Mar 2026 14:21:09 +0000 Subject: *: objecttype, objectheader -> object/type, object/header --- object/header/parse.go | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 object/header/parse.go (limited to 'object/header/parse.go') diff --git a/object/header/parse.go b/object/header/parse.go new file mode 100644 index 00000000..3751cafc --- /dev/null +++ b/object/header/parse.go @@ -0,0 +1,43 @@ +// Package objectheader parses and serializes object headers ("type size\0"). +package objectheader + +import ( + "bytes" + "strconv" + + objecttype "codeberg.org/lindenii/furgit/object/type" +) + +// Parse parses a canonical loose-object header ("type size\\x00"). +// It returns the parsed type, size, bytes consumed (including trailing NUL), +// and whether parsing succeeded. +func Parse(data []byte) (objecttype.Type, int64, int, bool) { + space := bytes.IndexByte(data, ' ') + if space <= 0 { + return objecttype.TypeInvalid, 0, 0, false + } + + nulRel := bytes.IndexByte(data[space+1:], 0) + if nulRel < 0 { + return objecttype.TypeInvalid, 0, 0, false + } + + nul := space + 1 + nulRel + + ty, ok := objecttype.ParseName(string(data[:space])) + if !ok { + return objecttype.TypeInvalid, 0, 0, false + } + + sizeBytes := data[space+1 : nul] + if len(sizeBytes) == 0 { + return objecttype.TypeInvalid, 0, 0, false + } + + size, err := strconv.ParseInt(string(sizeBytes), 10, 64) + if err != nil || size < 0 { + return objecttype.TypeInvalid, 0, 0, false + } + + return ty, size, nul + 1, true +} -- cgit v1.3.1-10-gc9f91