diff options
| author | 2026-03-29 14:42:13 +0000 | |
|---|---|---|
| committer | 2026-03-29 14:47:04 +0000 | |
| commit | df73a4c6f1b58075316ba7449fbfb127b9fbb79d (patch) | |
| tree | 62fee259ec037410b06419ee3ac9c2c189c35ab3 /commitquery/query_mark_phase.go | |
| parent | internal/priorityqueue: Update docs (diff) | |
| signature | No signature | |
commitquery: Reorganize
Diffstat (limited to 'commitquery/query_mark_phase.go')
| -rw-r--r-- | commitquery/query_mark_phase.go | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/commitquery/query_mark_phase.go b/commitquery/query_mark_phase.go new file mode 100644 index 00000000..0814df38 --- /dev/null +++ b/commitquery/query_mark_phase.go @@ -0,0 +1,36 @@ +package commitquery + +// beginMarkPhase starts one tracked mark-mutation phase. +func (query *query) beginMarkPhase() { + for _, idx := range query.touched { + query.nodes[idx].marks = 0 + } + + query.markPhase++ + if query.markPhase == 0 { + query.markPhase++ + for i := range query.nodes { + query.nodes[i].touchedPhase = 0 + } + } + + query.touched = query.touched[:0] +} + +// clearTouchedMarks clears the provided bits from all nodes touched in the +// current mark phase. +func (query *query) clearTouchedMarks(bits markBits) { + for _, idx := range query.touched { + query.nodes[idx].marks &^= bits + } +} + +// trackTouched records one node in the current mark phase. +func (query *query) trackTouched(idx nodeIndex) { + if query.nodes[idx].touchedPhase == query.markPhase { + return + } + + query.nodes[idx].touchedPhase = query.markPhase + query.touched = append(query.touched, idx) +} |
