Skip to content

Commit c2d9835

Browse files
committed
Merge pull request #91390 from kitbdev/add-selection-unhide-carets
Unhide carets in add selection for occurrence and fix error
2 parents 5fcd980 + 948f096 commit c2d9835

File tree

2 files changed

+45
-4
lines changed

2 files changed

+45
-4
lines changed

scene/gui/text_edit.cpp

+6-4
Original file line numberDiff line numberDiff line change
@@ -5174,7 +5174,7 @@ void TextEdit::add_selection_for_next_occurrence() {
51745174

51755175
const String &highlighted_text = get_selected_text(caret);
51765176
int column = get_selection_from_column(caret) + 1;
5177-
int line = get_caret_line(caret);
5177+
int line = get_selection_from_line(caret);
51785178

51795179
const Point2i next_occurrence = search(highlighted_text, SEARCH_MATCH_CASE, line, column);
51805180

@@ -5188,6 +5188,7 @@ void TextEdit::add_selection_for_next_occurrence() {
51885188

51895189
if (new_caret != -1) {
51905190
select(next_occurrence.y, next_occurrence.x, next_occurrence.y, end, new_caret);
5191+
_unhide_carets();
51915192
adjust_viewport_to_caret(new_caret);
51925193
merge_overlapping_carets();
51935194
}
@@ -5211,21 +5212,22 @@ void TextEdit::skip_selection_for_next_occurrence() {
52115212
// Due to const and &(reference) presence, ternary operator is a way to avoid errors and warnings.
52125213
const String &searched_text = has_selection(caret) ? get_selected_text(caret) : get_word_under_caret(caret);
52135214

5214-
int column = (has_selection(caret) ? get_selection_from_column(caret) : get_caret_column(caret)) + 1;
5215-
int line = get_caret_line(caret);
5215+
int column = get_selection_from_column(caret) + 1;
5216+
int line = get_selection_from_line(caret);
52165217

52175218
const Point2i next_occurrence = search(searched_text, SEARCH_MATCH_CASE, line, column);
52185219

52195220
if (next_occurrence.x == -1 || next_occurrence.y == -1) {
52205221
return;
52215222
}
52225223

5223-
int to_column = (has_selection(caret) ? get_selection_to_column(caret) : get_caret_column(caret)) + 1;
5224+
int to_column = get_selection_to_column(caret) + 1;
52245225
int end = next_occurrence.x + (to_column - column);
52255226
int new_caret = add_caret(next_occurrence.y, end);
52265227

52275228
if (new_caret != -1) {
52285229
select(next_occurrence.y, next_occurrence.x, next_occurrence.y, end, new_caret);
5230+
_unhide_carets();
52295231
adjust_viewport_to_caret(new_caret);
52305232
merge_overlapping_carets();
52315233
}

tests/scene/test_code_edit.h

+39
Original file line numberDiff line numberDiff line change
@@ -3331,6 +3331,45 @@ TEST_CASE("[SceneTree][CodeEdit] folding") {
33313331
CHECK_FALSE(code_edit->is_line_folded(1));
33323332
}
33333333

3334+
SUBCASE("[CodeEdit] actions unfold") {
3335+
// add_selection_for_next_occurrence unfolds.
3336+
code_edit->set_text("test\n\tline1 test\n\t\tline 2\ntest2");
3337+
code_edit->select(0, 0, 0, 4);
3338+
code_edit->fold_line(0);
3339+
CHECK(code_edit->is_line_folded(0));
3340+
code_edit->add_selection_for_next_occurrence();
3341+
3342+
CHECK(code_edit->get_caret_count() == 2);
3343+
CHECK(code_edit->has_selection(0));
3344+
CHECK(code_edit->get_caret_line() == 0);
3345+
CHECK(code_edit->get_selection_origin_line() == 0);
3346+
CHECK(code_edit->get_caret_column() == 4);
3347+
CHECK(code_edit->get_selection_origin_column() == 0);
3348+
CHECK(code_edit->has_selection(1));
3349+
CHECK(code_edit->get_caret_line(1) == 1);
3350+
CHECK(code_edit->get_selection_origin_line(1) == 1);
3351+
CHECK(code_edit->get_caret_column(1) == 11);
3352+
CHECK(code_edit->get_selection_origin_column(1) == 7);
3353+
CHECK_FALSE(code_edit->is_line_folded(0));
3354+
code_edit->remove_secondary_carets();
3355+
3356+
// skip_selection_for_next_occurrence unfolds.
3357+
code_edit->select(0, 0, 0, 4);
3358+
code_edit->fold_line(0);
3359+
CHECK(code_edit->is_line_folded(0));
3360+
code_edit->skip_selection_for_next_occurrence();
3361+
3362+
CHECK(code_edit->get_caret_count() == 1);
3363+
CHECK(code_edit->has_selection(0));
3364+
CHECK(code_edit->get_caret_line() == 1);
3365+
CHECK(code_edit->get_selection_origin_line() == 1);
3366+
CHECK(code_edit->get_caret_column() == 11);
3367+
CHECK(code_edit->get_selection_origin_column() == 7);
3368+
CHECK_FALSE(code_edit->is_line_folded(0));
3369+
code_edit->remove_secondary_carets();
3370+
code_edit->deselect();
3371+
}
3372+
33343373
SUBCASE("[CodeEdit] toggle folding carets") {
33353374
code_edit->set_text("test\n\tline1\ntest2\n\tline2");
33363375

0 commit comments

Comments
 (0)