From 1aa5cad4c8d6455eeb1f10893549e18bcca11996 Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Wed, 25 Mar 2026 19:33:32 +0000 Subject: object/fetch: Rename from object/resolve --- object/fetch/peel_to_commit_id.go | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 object/fetch/peel_to_commit_id.go (limited to 'object/fetch/peel_to_commit_id.go') diff --git a/object/fetch/peel_to_commit_id.go b/object/fetch/peel_to_commit_id.go new file mode 100644 index 00000000..b6b257cf --- /dev/null +++ b/object/fetch/peel_to_commit_id.go @@ -0,0 +1,39 @@ +package fetch + +import ( + "fmt" + + objectid "codeberg.org/lindenii/furgit/object/id" + objecttype "codeberg.org/lindenii/furgit/object/type" +) + +// PeelToCommitID peels tags until it reaches a commit object ID. +func (r *Fetcher) PeelToCommitID(id objectid.ObjectID) (objectid.ObjectID, error) { + for { + ty, _, err := r.store.ReadHeader(id) + if err != nil { + return objectid.ObjectID{}, err + } + + switch ty { + case objecttype.TypeCommit: + return id, nil + case objecttype.TypeTag: + tag, err := r.ExactTag(id) + if err != nil { + return objectid.ObjectID{}, err + } + + id = tag.Object().Target + case objecttype.TypeInvalid, + objecttype.TypeTree, + objecttype.TypeBlob, + objecttype.TypeFuture, + objecttype.TypeOfsDelta, + objecttype.TypeRefDelta: + return objectid.ObjectID{}, fmt.Errorf("object/fetch: expected commit-ish object %s, got %v", id, ty) + default: + return objectid.ObjectID{}, fmt.Errorf("object/fetch: expected commit-ish object %s, got %v", id, ty) + } + } +} -- cgit v1.3.1-10-gc9f91