diff options
| author | 2026-03-28 17:40:02 +0000 | |
|---|---|---|
| committer | 2026-03-28 17:40:02 +0000 | |
| commit | 06583274fa64ad6677773bf4ca54f69226388203 (patch) | |
| tree | 66354bf972d267bf7ee5135eb7e5b90c31f9fe4d /commitquery/queries_mergebase.go | |
| parent | format/commitgraph/read: Lifetime (diff) | |
| signature | No signature | |
commitquery: Make a reusable engine thingy
Diffstat (limited to 'commitquery/queries_mergebase.go')
| -rw-r--r-- | commitquery/queries_mergebase.go | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/commitquery/queries_mergebase.go b/commitquery/queries_mergebase.go new file mode 100644 index 00000000..ff0aafb9 --- /dev/null +++ b/commitquery/queries_mergebase.go @@ -0,0 +1,21 @@ +package commitquery + +import objectid "codeberg.org/lindenii/furgit/object/id" + +// MergeBases reports all merge bases in Git's merge-base --all order. +// +// Both inputs are peeled through annotated tags before commit traversal. +func (queries *Queries) MergeBases(left, right objectid.ObjectID) ([]objectid.ObjectID, error) { + query := queries.acquire() + defer queries.release(query) + + return query.MergeBases(left, right) +} + +// MergeBase reports one merge base between left and right, if any. +func (queries *Queries) MergeBase(left, right objectid.ObjectID) (objectid.ObjectID, bool, error) { + query := queries.acquire() + defer queries.release(query) + + return query.MergeBase(left, right) +} |
