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