summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-03-09 00:52:05 +0100
committerRémi Verschelde <rverschelde@gmail.com>2024-03-09 00:52:05 +0100
commitd78fafa4b049f4e2b792b90153a6c2ebafa75dd8 (patch)
tree0aa465e373bdfcac459e762b0cb06fcbe4d9f8e7
parentbaf75d048cb78881585c8d70a38156d4dd1c0d17 (diff)
parentbfd17009711ee655c673c191fec1724c67105311 (diff)
downloadredot-engine-d78fafa4b049f4e2b792b90153a6c2ebafa75dd8.tar.gz
Merge pull request #89085 from miv391/remember-search-replace-text
Remember search text in Find/Replace in Files dialog
-rw-r--r--editor/find_in_files.cpp23
1 files changed, 18 insertions, 5 deletions
diff --git a/editor/find_in_files.cpp b/editor/find_in_files.cpp
index 6d690cf31b..965cb39df3 100644
--- a/editor/find_in_files.cpp
+++ b/editor/find_in_files.cpp
@@ -398,8 +398,24 @@ FindInFilesDialog::FindInFilesDialog() {
}
void FindInFilesDialog::set_search_text(const String &text) {
- _search_text_line_edit->set_text(text);
- _on_search_text_modified(text);
+ if (_mode == SEARCH_MODE) {
+ if (!text.is_empty()) {
+ _search_text_line_edit->set_text(text);
+ _on_search_text_modified(text);
+ }
+ callable_mp((Control *)_search_text_line_edit, &Control::grab_focus).call_deferred();
+ _search_text_line_edit->select_all();
+ } else if (_mode == REPLACE_MODE) {
+ if (!text.is_empty()) {
+ _search_text_line_edit->set_text(text);
+ callable_mp((Control *)_replace_text_line_edit, &Control::grab_focus).call_deferred();
+ _replace_text_line_edit->select_all();
+ _on_search_text_modified(text);
+ } else {
+ callable_mp((Control *)_search_text_line_edit, &Control::grab_focus).call_deferred();
+ _search_text_line_edit->select_all();
+ }
+ }
}
void FindInFilesDialog::set_replace_text(const String &text) {
@@ -464,9 +480,6 @@ void FindInFilesDialog::_notification(int p_what) {
switch (p_what) {
case NOTIFICATION_VISIBILITY_CHANGED: {
if (is_visible()) {
- // Doesn't work more than once if not deferred...
- callable_mp((Control *)_search_text_line_edit, &Control::grab_focus).call_deferred();
- _search_text_line_edit->select_all();
// Extensions might have changed in the meantime, we clean them and instance them again.
for (int i = 0; i < _filters_container->get_child_count(); i++) {
_filters_container->get_child(i)->queue_free();