From df73a4c6f1b58075316ba7449fbfb127b9fbb79d Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Sun, 29 Mar 2026 14:42:13 +0000 Subject: commitquery: Reorganize --- commitquery/query_merge_bases_internal.go | 34 +++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 commitquery/query_merge_bases_internal.go (limited to 'commitquery/query_merge_bases_internal.go') diff --git a/commitquery/query_merge_bases_internal.go b/commitquery/query_merge_bases_internal.go new file mode 100644 index 00000000..2d133435 --- /dev/null +++ b/commitquery/query_merge_bases_internal.go @@ -0,0 +1,34 @@ +package commitquery + +import "slices" + +// mergeBases returns internal merge-base candidates for two resolved nodes. +func (query *query) mergeBases(left, right nodeIndex) ([]nodeIndex, error) { + if left == right { + return []nodeIndex{left}, nil + } + + err := query.paintDownToCommon(left, []nodeIndex{right}, 0) + if err != nil { + return nil, err + } + + candidates := query.collectMarkedResults() + + if len(candidates) <= 1 { + slices.SortFunc(candidates, query.compare) + + return candidates, nil + } + + query.clearTouchedMarks(allMarks) + + reduced, err := removeRedundant(query, candidates) + if err != nil { + return nil, err + } + + slices.SortFunc(reduced, query.compare) + + return reduced, nil +} -- cgit v1.3.1-10-gc9f91