From f2922155de01b734e3e8b3f50be8f263ec13cacd Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Fri, 6 Mar 2026 18:38:44 +0800 Subject: *: Lint --- object/parse.go | 34 +++++++++++++++++++--------------- 1 file changed, 19 insertions(+), 15 deletions(-) (limited to 'object/parse.go') diff --git a/object/parse.go b/object/parse.go index 1b15f377..9afe5cb8 100644 --- a/object/parse.go +++ b/object/parse.go @@ -8,7 +8,26 @@ import ( "codeberg.org/lindenii/furgit/objecttype" ) +// ParseObjectWithHeader parses a loose object in "type size\x00body" format. +// +//nolint:ireturn +func ParseObjectWithHeader(raw []byte, algo objectid.Algorithm) (Object, error) { + ty, size, headerLen, ok := objectheader.Parse(raw) + if !ok { + return nil, fmt.Errorf("object: malformed object header") + } + + body := raw[headerLen:] + if int64(len(body)) != size { + return nil, fmt.Errorf("object: size mismatch: header says %d bytes, body has %d", size, len(body)) + } + + return ParseObjectWithoutHeader(ty, body, algo) +} + // ParseObjectWithoutHeader parses a typed object body. +// +//nolint:ireturn func ParseObjectWithoutHeader(ty objecttype.Type, body []byte, algo objectid.Algorithm) (Object, error) { switch ty { case objecttype.TypeBlob: @@ -25,18 +44,3 @@ func ParseObjectWithoutHeader(ty objecttype.Type, body []byte, algo objectid.Alg return nil, fmt.Errorf("object: unsupported object type %d", ty) } } - -// ParseObjectWithHeader parses a loose object in "type size\\x00body" format. -func ParseObjectWithHeader(raw []byte, algo objectid.Algorithm) (Object, error) { - ty, size, headerLen, ok := objectheader.Parse(raw) - if !ok { - return nil, fmt.Errorf("object: malformed object header") - } - - body := raw[headerLen:] - if int64(len(body)) != size { - return nil, fmt.Errorf("object: size mismatch: header says %d bytes, body has %d", size, len(body)) - } - - return ParseObjectWithoutHeader(ty, body, algo) -} -- cgit v1.3.1-10-gc9f91