From 62d363f044dbcd5dbdf447a0f3ce4c12b8ab30e4 Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Sat, 16 May 2026 08:29:46 +0000 Subject: object/header: Refactor --- object/header/parse.go | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) (limited to 'object/header/parse.go') diff --git a/object/header/parse.go b/object/header/parse.go index 77deef38..7fb3ed04 100644 --- a/object/header/parse.go +++ b/object/header/parse.go @@ -2,39 +2,42 @@ package header import ( "bytes" + "errors" "strconv" "codeberg.org/lindenii/furgit/object/typ" ) +var ErrInvalidHeader = errors.New("object/header: invalid header") + // Parse parses a canonical loose-object header ("type size\x00"). -func Parse(data []byte) (ty typ.Type, size int64, consumed int, ok bool) { +func Parse(data []byte) (ty typ.Type, size uint64, consumed int, err error) { space := bytes.IndexByte(data, ' ') if space <= 0 { - return typ.TypeInvalid, 0, 0, false + return 0, 0, 0, ErrInvalidHeader } nulRel := bytes.IndexByte(data[space+1:], 0) if nulRel < 0 { - return typ.TypeInvalid, 0, 0, false + return 0, 0, 0, ErrInvalidHeader } nul := space + 1 + nulRel - ty, ok = typ.Parse(string(data[:space])) - if !ok { - return typ.TypeInvalid, 0, 0, false + ty, err = typ.Parse(string(data[:space])) + if err != nil { + return 0, 0, 0, ErrInvalidHeader } sizeBytes := data[space+1 : nul] if len(sizeBytes) == 0 { - return typ.TypeInvalid, 0, 0, false + return 0, 0, 0, ErrInvalidHeader } - size, err := strconv.ParseInt(string(sizeBytes), 10, 64) - if err != nil || size < 0 { - return typ.TypeInvalid, 0, 0, false + size, err = strconv.ParseUint(string(sizeBytes), 10, 64) + if err != nil { + return 0, 0, 0, ErrInvalidHeader } - return ty, size, nul + 1, true + return ty, size, nul + 1, nil } -- cgit v1.3.1-10-gc9f91