From 01d15bccf3b1dcc51516b1f64d50950b31d7f8fb Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Fri, 6 Mar 2026 21:19:56 +0800 Subject: Urgh I made some wrong amends and I'm too tired to separate the commits out this time ancestor: Split out of reachability mergebase: Add merge base routines internal/commitquery: Add commit query context engine thingy internal/peel: Shared tag peeling errors: Shared object query errors internal/testgit: Add rooted repo helpers; remove raw path access objectstore/memory: Add in-memory object store objectid: Add Compare helper --- errors/type.go | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 errors/type.go (limited to 'errors/type.go') diff --git a/errors/type.go b/errors/type.go new file mode 100644 index 00000000..82ca993a --- /dev/null +++ b/errors/type.go @@ -0,0 +1,31 @@ +package errors + +import ( + "fmt" + + "codeberg.org/lindenii/furgit/objectid" + "codeberg.org/lindenii/furgit/objecttype" +) + +// ObjectTypeError indicates that a referenced object has a different type than +// what the operation expected. +type ObjectTypeError struct { + OID objectid.ObjectID + Got objecttype.Type + Want objecttype.Type +} + +// Error implements error. +func (e *ObjectTypeError) Error() string { + gotName, gotOK := objecttype.Name(e.Got) + if !gotOK { + gotName = fmt.Sprintf("type(%d)", e.Got) + } + + wantName, wantOK := objecttype.Name(e.Want) + if !wantOK { + wantName = fmt.Sprintf("type(%d)", e.Want) + } + + return fmt.Sprintf("object %s has type %s, want %s", e.OID, gotName, wantName) +} -- cgit v1.3.1-10-gc9f91