aboutsummaryrefslogtreecommitdiff
path: root/commitquery/queries_mergebase.go
diff options
context:
space:
mode:
authorGravatar Runxi Yu2026-03-28 17:40:02 +0000
committerGravatar Runxi Yu2026-03-28 17:40:02 +0000
commit06583274fa64ad6677773bf4ca54f69226388203 (patch)
tree66354bf972d267bf7ee5135eb7e5b90c31f9fe4d /commitquery/queries_mergebase.go
parentformat/commitgraph/read: Lifetime (diff)
signatureNo signature
commitquery: Make a reusable engine thingy
Diffstat (limited to 'commitquery/queries_mergebase.go')
-rw-r--r--commitquery/queries_mergebase.go21
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)
+}