Skip to content

Commit

Permalink
Merge pull request #82707 from BrianMacIntosh/find-highlight-fix
Browse files Browse the repository at this point in the history
Search terms are now highlighted when the bar opens with a selection.
  • Loading branch information
akien-mga committed Oct 30, 2023
2 parents be8761a + 0d7db93 commit ec5bfbd
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 30 deletions.
50 changes: 20 additions & 30 deletions editor/code_editor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,20 @@ void FindReplaceBar::_focus_lost() {
}
}

void FindReplaceBar::_update_flags(bool p_direction_backwards) {
flags = 0;

if (is_whole_words()) {
flags |= TextEdit::SEARCH_WHOLE_WORDS;
}
if (is_case_sensitive()) {
flags |= TextEdit::SEARCH_MATCH_CASE;
}
if (p_direction_backwards) {
flags |= TextEdit::SEARCH_BACKWARDS;
}
}

bool FindReplaceBar::_search(uint32_t p_flags, int p_from_line, int p_from_col) {
if (!preserve_cursor) {
text_editor->remove_secondary_carets();
Expand Down Expand Up @@ -431,14 +445,7 @@ void FindReplaceBar::_update_matches_label() {
}

bool FindReplaceBar::search_current() {
flags = 0;

if (is_whole_words()) {
flags |= TextEdit::SEARCH_WHOLE_WORDS;
}
if (is_case_sensitive()) {
flags |= TextEdit::SEARCH_MATCH_CASE;
}
_update_flags(false);

int line, col;
_get_search_from(line, col);
Expand All @@ -455,17 +462,9 @@ bool FindReplaceBar::search_prev() {
popup_search(true);
}

flags = 0;
String text = get_search_text();

if (is_whole_words()) {
flags |= TextEdit::SEARCH_WHOLE_WORDS;
}
if (is_case_sensitive()) {
flags |= TextEdit::SEARCH_MATCH_CASE;
}

flags |= TextEdit::SEARCH_BACKWARDS;
_update_flags(true);

int line, col;
_get_search_from(line, col);
Expand All @@ -491,14 +490,7 @@ bool FindReplaceBar::search_next() {
popup_search(true);
}

flags = 0;

if (is_whole_words()) {
flags |= TextEdit::SEARCH_WHOLE_WORDS;
}
if (is_case_sensitive()) {
flags |= TextEdit::SEARCH_MATCH_CASE;
}
_update_flags(false);

int line, col;
_get_search_from(line, col, true);
Expand Down Expand Up @@ -546,11 +538,9 @@ void FindReplaceBar::_show_search(bool p_focus_replace, bool p_show_only) {
search_text->set_caret_column(search_text->get_text().length());
}

results_count = -1;
results_count_to_current = -1;
needs_to_count_results = true;
_update_results_count();
_update_matches_label();
preserve_cursor = true;
_search_text_changed(get_search_text());
preserve_cursor = false;
}
}

Expand Down
2 changes: 2 additions & 0 deletions editor/code_editor.h
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,8 @@ class FindReplaceBar : public HBoxContainer {
virtual void unhandled_input(const Ref<InputEvent> &p_event) override;
void _focus_lost();

void _update_flags(bool p_direction_backwards);

bool _search(uint32_t p_flags, int p_from_line, int p_from_col);

void _replace();
Expand Down

0 comments on commit ec5bfbd

Please sign in to comment.