From 19bdbd093c0972c8a6a5dd86eb7c75ede031d316 Mon Sep 17 00:00:00 2001 From: Scott Sumner <30118311+sasumner@users.noreply.github.com> Date: Fri, 19 Jun 2020 09:05:08 -0400 Subject: [PATCH] Add confirmation prompt to Replace-in-all-opened-docs command Fix #5253, fix #8432, close #8438 --- PowerEditor/installer/nativeLang/english.xml | 2 + .../src/ScitillaComponent/FindReplaceDlg.cpp | 50 ++++++++++++++----- .../src/ScitillaComponent/FindReplaceDlg.h | 1 + 3 files changed, 40 insertions(+), 13 deletions(-) diff --git a/PowerEditor/installer/nativeLang/english.xml b/PowerEditor/installer/nativeLang/english.xml index 3f55a1ed4..abd763355 100644 --- a/PowerEditor/installer/nativeLang/english.xml +++ b/PowerEditor/installer/nativeLang/english.xml @@ -1268,6 +1268,8 @@ Find in all files except exe, obj && log: + + diff --git a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp index cce6a6ab1..c66121ff8 100644 --- a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp +++ b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp @@ -1266,17 +1266,20 @@ INT_PTR CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM if (_currentStatus == REPLACE_DLG) { - setStatusbarMessage(TEXT(""), FSNoMessage); - HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); - _options._str2Search = getTextFromCombo(hFindCombo); - HWND hReplaceCombo = ::GetDlgItem(_hSelf, IDREPLACEWITH); - _options._str4Replace = getTextFromCombo(hReplaceCombo); - updateCombos(); + if (replaceInOpenDocsConfirmCheck()) + { + setStatusbarMessage(TEXT(""), FSNoMessage); + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo); + HWND hReplaceCombo = ::GetDlgItem(_hSelf, IDREPLACEWITH); + _options._str4Replace = getTextFromCombo(hReplaceCombo); + updateCombos(); - nppParamInst._isFindReplacing = true; - if (isMacroRecording) saveInMacro(wParam, FR_OP_REPLACE + FR_OP_GLOBAL); - replaceAllInOpenedDocs(); - nppParamInst._isFindReplacing = false; + nppParamInst._isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_REPLACE + FR_OP_GLOBAL); + replaceAllInOpenedDocs(); + nppParamInst._isFindReplacing = false; + } } } return TRUE; @@ -2811,9 +2814,12 @@ void FindReplaceDlg::execSavedCommand(int cmd, uptr_t intValue, const generic_st nppParamInst._isFindReplacing = false; break; case IDC_REPLACE_OPENEDFILES: - nppParamInst._isFindReplacing = true; - replaceAllInOpenedDocs(); - nppParamInst._isFindReplacing = false; + if (replaceInOpenDocsConfirmCheck()) + { + nppParamInst._isFindReplacing = true; + replaceAllInOpenedDocs(); + nppParamInst._isFindReplacing = false; + } break; case IDD_FINDINFILES_FIND_BUTTON: nppParamInst._isFindReplacing = true; @@ -3227,6 +3233,24 @@ bool FindReplaceDlg::replaceInFilesConfirmCheck(generic_string directory, generi return confirmed; } +bool FindReplaceDlg::replaceInOpenDocsConfirmCheck(void) +{ + bool confirmed = false; + + NativeLangSpeaker* pNativeSpeaker = (NppParameters::getInstance()).getNativeLangSpeaker(); + generic_string title = pNativeSpeaker->getLocalizedStrFromID("replace-in-open-docs-confirm-title", TEXT("Are you sure?")); + generic_string msg = pNativeSpeaker->getLocalizedStrFromID("replace-in-open-docs-confirm-message", TEXT("Are you sure you want to replace all occurrences in all open documents?")); + + int res = ::MessageBox(NULL, msg.c_str(), title.c_str(), MB_OKCANCEL | MB_DEFBUTTON2 | MB_TASKMODAL); + + if (res == IDOK) + { + confirmed = true; + } + + return confirmed; +} + generic_string Finder::getHitsString(int count) const { NativeLangSpeaker *pNativeSpeaker = (NppParameters::getInstance()).getNativeLangSpeaker(); diff --git a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h index 4c44addf0..e7f6c3ecf 100644 --- a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h +++ b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h @@ -417,6 +417,7 @@ private : void saveInMacro(size_t cmd, int cmdType); void drawItem(LPDRAWITEMSTRUCT lpDrawItemStruct); bool replaceInFilesConfirmCheck(generic_string directory, generic_string fileTypes); + bool replaceInOpenDocsConfirmCheck(void); }; //FindIncrementDlg: incremental search dialog, docked in rebar