diff --git a/PowerEditor/src/MISC/Common/Common.h b/PowerEditor/src/MISC/Common/Common.h index e61be4aed..d3b4ca70d 100644 --- a/PowerEditor/src/MISC/Common/Common.h +++ b/PowerEditor/src/MISC/Common/Common.h @@ -124,9 +124,11 @@ protected: private: // Since there's no public ctor, we need to void the default assignment operator. WcharMbcsConvertor& operator= (const WcharMbcsConvertor&); - + }; +#define MACRO_RECORDING_IN_PROGRESS 1 +#define MACRO_RECORDING_HAS_STOPPED 2 #if _MSC_VER > 1400 // MS Compiler > VS 2005 #define REBARBAND_SIZE REBARBANDINFO_V3_SIZE diff --git a/PowerEditor/src/Notepad_plus.cpp b/PowerEditor/src/Notepad_plus.cpp index 524984ac6..ae1894656 100644 --- a/PowerEditor/src/Notepad_plus.cpp +++ b/PowerEditor/src/Notepad_plus.cpp @@ -888,7 +888,7 @@ bool Notepad_plus::replaceAllFiles() { _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); _invisibleEditView._currentBuffer = pBuf; _invisibleEditView.execute(SCI_BEGINUNDOACTION); - nbTotal += _findReplaceDlg.processAll(ProcessReplaceAll, NULL, NULL, isEntireDoc, NULL); + nbTotal += _findReplaceDlg.processAll(ProcessReplaceAll, FindReplaceDlg::_env, isEntireDoc); _invisibleEditView.execute(SCI_ENDUNDOACTION); } } @@ -905,7 +905,7 @@ bool Notepad_plus::replaceAllFiles() { _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); _invisibleEditView._currentBuffer = pBuf; _invisibleEditView.execute(SCI_BEGINUNDOACTION); - nbTotal += _findReplaceDlg.processAll(ProcessReplaceAll, NULL, NULL, isEntireDoc, NULL); + nbTotal += _findReplaceDlg.processAll(ProcessReplaceAll, FindReplaceDlg::_env, isEntireDoc); _invisibleEditView.execute(SCI_ENDUNDOACTION); } } @@ -1094,7 +1094,7 @@ bool Notepad_plus::replaceInFiles() _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); _invisibleEditView._currentBuffer = pBuf; - int nbReplaced = _findReplaceDlg.processAll(ProcessReplaceAll, NULL, NULL, true, fileNames.at(i).c_str()); + int nbReplaced = _findReplaceDlg.processAll(ProcessReplaceAll, FindReplaceDlg::_env, true, fileNames.at(i).c_str()); nbTotal += nbReplaced; if (nbReplaced) { @@ -1176,7 +1176,7 @@ bool Notepad_plus::findInFiles() int cp = _invisibleEditView.execute(SCI_GETCODEPAGE); _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); - nbTotal += _findReplaceDlg.processAll(ProcessFindAll, NULL, NULL, true, fileNames.at(i).c_str()); + nbTotal += _findReplaceDlg.processAll(ProcessFindAll, FindReplaceDlg::_env, true, fileNames.at(i).c_str()); if (!dontClose) MainFileManager->closeBuffer(id, _pEditView); } @@ -1220,7 +1220,7 @@ bool Notepad_plus::findInOpenedFiles() _invisibleEditView.execute(SCI_SETDOCPOINTER, 0, pBuf->getDocument()); int cp = _invisibleEditView.execute(SCI_GETCODEPAGE); _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); - nbTotal += _findReplaceDlg.processAll(ProcessFindAll, NULL, NULL, isEntireDoc, pBuf->getFullPathName()); + nbTotal += _findReplaceDlg.processAll(ProcessFindAll, FindReplaceDlg::_env, isEntireDoc, pBuf->getFullPathName()); } } @@ -1232,7 +1232,7 @@ bool Notepad_plus::findInOpenedFiles() _invisibleEditView.execute(SCI_SETDOCPOINTER, 0, pBuf->getDocument()); int cp = _invisibleEditView.execute(SCI_GETCODEPAGE); _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); - nbTotal += _findReplaceDlg.processAll(ProcessFindAll, NULL, NULL, isEntireDoc, pBuf->getFullPathName()); + nbTotal += _findReplaceDlg.processAll(ProcessFindAll, FindReplaceDlg::_env, isEntireDoc, pBuf->getFullPathName()); } } @@ -1265,7 +1265,7 @@ bool Notepad_plus::findInCurrentFile() _invisibleEditView.execute(SCI_SETDOCPOINTER, 0, pBuf->getDocument()); int cp = _invisibleEditView.execute(SCI_GETCODEPAGE); _invisibleEditView.execute(SCI_SETCODEPAGE, pBuf->getUnicodeMode() == uni8Bit ? cp : SC_CP_UTF8); - nbTotal += _findReplaceDlg.processAll(ProcessFindAll, NULL, NULL, isEntireDoc, pBuf->getFullPathName()); + nbTotal += _findReplaceDlg.processAll(ProcessFindAll, FindReplaceDlg::_env, isEntireDoc, pBuf->getFullPathName()); _findReplaceDlg.finishFilesSearch(nbTotal); diff --git a/PowerEditor/src/Notepad_plus.h b/PowerEditor/src/Notepad_plus.h index 7995c8015..3f3b97c20 100644 --- a/PowerEditor/src/Notepad_plus.h +++ b/PowerEditor/src/Notepad_plus.h @@ -262,6 +262,7 @@ public: bool addCurrentMacro(); + void macroPlayback(Macro); void loadLastSession(){ Session lastSession = (NppParameters::getInstance())->getSession(); diff --git a/PowerEditor/src/NppBigSwitch.cpp b/PowerEditor/src/NppBigSwitch.cpp index f0972ad06..26070507e 100644 --- a/PowerEditor/src/NppBigSwitch.cpp +++ b/PowerEditor/src/NppBigSwitch.cpp @@ -934,8 +934,17 @@ LRESULT Notepad_plus::process(HWND hwnd, UINT Message, WPARAM wParam, LPARAM lPa return MAKELONG(auxVer, mainVer); } - case WM_ISCURRENTMACRORECORDED : - return (!_macro.empty() && !_recordingMacro); + case WM_GETCURRENTMACROSTATUS : + if (_recordingMacro) return MACRO_RECORDING_IN_PROGRESS; + return (_macro.empty())?0:MACRO_RECORDING_HAS_STOPPED; + + case WM_FRSAVE_INT: + _macro.push_back(recordedMacroStep(wParam, 0, lParam, NULL)); + break; + + case WM_FRSAVE_STR: + _macro.push_back(recordedMacroStep(wParam, 0, 0, (const TCHAR *)lParam)); + break; case WM_MACRODLGRUNMACRO: { diff --git a/PowerEditor/src/NppCommands.cpp b/PowerEditor/src/NppCommands.cpp index a4739af80..90419307b 100644 --- a/PowerEditor/src/NppCommands.cpp +++ b/PowerEditor/src/NppCommands.cpp @@ -21,6 +21,20 @@ #include "ShortcutMapper.h" #include "TaskListDlg.h" +void Notepad_plus::macroPlayback(Macro macro) +{ + _pEditView->execute(SCI_BEGINUNDOACTION); + + for (Macro::iterator step = macro.begin(); step != macro.end(); step++) + { + if (step->isPlayable()) + step->PlayBack(this->_pPublicInterface, _pEditView); + else + _findReplaceDlg.execSavedCommand(step->message, step->lParameter, step->sParameter); + } + + _pEditView->execute(SCI_ENDUNDOACTION); +} void Notepad_plus::command(int id) { @@ -165,14 +179,7 @@ void Notepad_plus::command(int id) case IDM_MACRO_PLAYBACKRECORDEDMACRO: if (!_recordingMacro) // if we're not currently recording, then playback the recorded keystrokes - { - _pEditView->execute(SCI_BEGINUNDOACTION); - - for (Macro::iterator step = _macro.begin(); step != _macro.end(); step++) - step->PlayBack(this->_pPublicInterface, _pEditView); - - _pEditView->execute(SCI_ENDUNDOACTION); - } + macroPlayback(_macro); break; case IDM_MACRO_RUNMULTIMACRODLG : @@ -1861,14 +1868,7 @@ void Notepad_plus::command(int id) { int i = id - ID_MACRO; vector & theMacros = (NppParameters::getInstance())->getMacroList(); - Macro macro = theMacros[i].getMacro(); - _pEditView->execute(SCI_BEGINUNDOACTION); - - for (Macro::iterator step = macro.begin(); step != macro.end(); step++) - step->PlayBack(this->_pPublicInterface, _pEditView); - - _pEditView->execute(SCI_ENDUNDOACTION); - + macroPlayback(theMacros[i].getMacro()); } else if ((id >= ID_USER_CMD) && (id < ID_USER_CMD_LIMIT)) { diff --git a/PowerEditor/src/Parameters.cpp b/PowerEditor/src/Parameters.cpp index 78489356f..c2e2c95e8 100644 --- a/PowerEditor/src/Parameters.cpp +++ b/PowerEditor/src/Parameters.cpp @@ -1820,7 +1820,7 @@ void NppParameters::getActions(TiXmlNode *node, Macro & macro) { int type; const TCHAR *typeStr = (childNode->ToElement())->Attribute(TEXT("type"), &type); - if ((!typeStr) || (type > 2)) + if ((!typeStr) || (type > 3)) continue; int msg = 0; @@ -1835,7 +1835,7 @@ void NppParameters::getActions(TiXmlNode *node, Macro & macro) const TCHAR *sParam = (childNode->ToElement())->Attribute(TEXT("sParam")); if (!sParam) sParam = TEXT(""); - recordedMacroStep step(type, msg, wParam, lParam, sParam); + recordedMacroStep step(msg, wParam, lParam, sParam, type); if (step.isValid()) macro.push_back(step); @@ -5144,3 +5144,4 @@ void NppParameters::addScintillaModifiedIndex(int index) _scintillaModifiedKeyIndices.push_back(index); } } + diff --git a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp index 742ebbe2e..53905fdd6 100644 --- a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp +++ b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.cpp @@ -21,6 +21,9 @@ #include "Notepad_plus_msgs.h" #include "UniConversion.h" +FindOption * FindReplaceDlg::_env; +FindOption FindReplaceDlg::_options; + int Searching::convertExtendedToString(const TCHAR * query, TCHAR * result, int length) { //query may equal to result, since it always gets smaller int i = 0, j = 0; int charLeft = length; @@ -680,27 +683,27 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP CharacterRange cr = (*_ppEditView)->getSelection(); int nbSelected = cr.cpMax - cr.cpMin; - _isInSelection = isCheckedOrNot(IDC_IN_SELECTION_CHECK)?1:0; - int checkVal = _isInSelection?BST_CHECKED:BST_UNCHECKED; + _options._isInSelection = isCheckedOrNot(IDC_IN_SELECTION_CHECK)?1:0; + int checkVal = _options._isInSelection?BST_CHECKED:BST_UNCHECKED; - if (!_isInSelection) + if (!_options._isInSelection) { if (nbSelected <= 1024) { checkVal = BST_UNCHECKED; - _isInSelection = false; + _options._isInSelection = false; } else { checkVal = BST_CHECKED; - _isInSelection = true; + _options._isInSelection = true; } } // Searching/replacing in column selection is not allowed if ((*_ppEditView)->execute(SCI_GETSELECTIONMODE) == SC_SEL_RECTANGLE) { checkVal = BST_UNCHECKED; - _isInSelection = false; + _options._isInSelection = false; nbSelected = 0; } ::EnableWindow(::GetDlgItem(_hSelf, IDC_IN_SELECTION_CHECK), nbSelected); @@ -708,7 +711,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP if (!nbSelected) { checkVal = BST_UNCHECKED; - _isInSelection = false; + _options._isInSelection = false; } ::SendDlgItemMessage(_hSelf, IDC_IN_SELECTION_CHECK, BM_SETCHECK, checkVal, 0); } @@ -733,25 +736,26 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case WM_COMMAND : { + bool isMacroRecording = (::SendMessage(_hParent, WM_GETCURRENTMACROSTATUS,0,0) == MACRO_RECORDING_IN_PROGRESS); NppParameters *nppParamInst = NppParameters::getInstance(); FindHistory & findHistory = nppParamInst->getFindHistory(); switch (wParam) { - case IDCANCEL : // Close - display(false); - return TRUE; - //Single actions + case IDCANCEL: + display(false); + break; case IDOK : // Find Next : only for FIND_DLG and REPLACE_DLG { bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); - generic_string str2Search = getTextFromCombo(hFindCombo, isUnicode); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); updateCombo(IDFINDWHAT); nppParamInst->_isFindReplacing = true; - processFindNext(str2Search.c_str()); + if (isMacroRecording) saveInMacro(wParam, FR_OP_FIND); + processFindNext(_options._str2Search.c_str()); nppParamInst->_isFindReplacing = false; } return TRUE; @@ -763,12 +767,13 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); HWND hReplaceCombo = ::GetDlgItem(_hSelf, IDREPLACEWITH); - generic_string str2Search = getTextFromCombo(hFindCombo, isUnicode); - generic_string str2Replace = getTextFromCombo(hReplaceCombo, isUnicode); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); + _options._str4Replace = getTextFromCombo(hReplaceCombo, isUnicode); updateCombos(); nppParamInst->_isFindReplacing = true; - processReplace(str2Search.c_str(), str2Replace.c_str()); + if (isMacroRecording) saveInMacro(wParam, FR_OP_REPLACE); + processReplace(_options._str2Search.c_str(), _options._str4Replace.c_str()); nppParamInst->_isFindReplacing = false; } } @@ -778,10 +783,14 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == FIND_DLG) { + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); combo2ExtendedMode(IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); updateCombo(IDFINDWHAT); nppParamInst->_isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_FIND + FR_OP_GLOBAL); findAllIn(ALL_OPEN_DOCS); nppParamInst->_isFindReplacing = false; } @@ -790,10 +799,14 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDC_FINDALL_CURRENTFILE : { + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); combo2ExtendedMode(IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); updateCombo(IDFINDWHAT); nppParamInst->_isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_FIND + FR_OP_GLOBAL); findAllIn(CURRENT_DOC); nppParamInst->_isFindReplacing = false; } @@ -802,23 +815,28 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDD_FINDINFILES_FIND_BUTTON : { const int filterSize = 256; - TCHAR filters[filterSize]; + TCHAR filters[filterSize+1]; + filters[filterSize] = '\0'; TCHAR directory[MAX_PATH]; ::GetDlgItemText(_hSelf, IDD_FINDINFILES_FILTERS_COMBO, filters, filterSize); addText2Combo(filters, ::GetDlgItem(_hSelf, IDD_FINDINFILES_FILTERS_COMBO)); - _filters = filters; + _options._filters = filters; ::GetDlgItemText(_hSelf, IDD_FINDINFILES_DIR_COMBO, directory, MAX_PATH); addText2Combo(directory, ::GetDlgItem(_hSelf, IDD_FINDINFILES_DIR_COMBO)); - _directory = directory; + _options._directory = directory; if ((lstrlen(directory) > 0) && (directory[lstrlen(directory)-1] != '\\')) - _directory += TEXT("\\"); + _options._directory += TEXT("\\"); - combo2ExtendedMode(IDFINDWHAT); + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); + combo2ExtendedMode(IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); updateCombo(IDFINDWHAT); nppParamInst->_isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_FIND + FR_OP_FIF); findAllIn(FILES_IN_DIR); nppParamInst->_isFindReplacing = false; } @@ -831,26 +849,32 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP TCHAR directory[MAX_PATH]; ::GetDlgItemText(_hSelf, IDD_FINDINFILES_FILTERS_COMBO, filters, filterSize); addText2Combo(filters, ::GetDlgItem(_hSelf, IDD_FINDINFILES_FILTERS_COMBO)); - _filters = filters; + _options._filters = filters; ::GetDlgItemText(_hSelf, IDD_FINDINFILES_DIR_COMBO, directory, MAX_PATH); addText2Combo(directory, ::GetDlgItem(_hSelf, IDD_FINDINFILES_DIR_COMBO)); - _directory = directory; + _options._directory = directory; if ((lstrlen(directory) > 0) && (directory[lstrlen(directory)-1] != '\\')) - _directory += TEXT("\\"); + _options._directory += TEXT("\\"); generic_string msg = TEXT("Are you sure you want to replace all occurances in :\r"); - msg += _directory; + msg += _options._directory; msg += TEXT("\rfor file type : "); - msg += _filters[0]?_filters:TEXT("*.*"); + msg += _options._filters[0]?_options._filters:TEXT("*.*"); - if (::MessageBox(_hSelf, msg.c_str(), TEXT("Are you sure?"), MB_OKCANCEL) == IDOK) + if (::MessageBox(_hMsgParent, msg.c_str(), TEXT("Are you sure?"), MB_OKCANCEL) == IDOK) { + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); + HWND hReplaceCombo = ::GetDlgItem(_hSelf, IDREPLACEWITH); + _options._str4Replace = getTextFromCombo(hReplaceCombo, isUnicode); updateCombo(IDFINDWHAT); updateCombo(IDREPLACEWITH); nppParamInst->_isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_REPLACE + FR_OP_FIF); ::SendMessage(_hParent, WM_REPLACEINFILES, 0, 0); nppParamInst->_isFindReplacing = false; } @@ -861,9 +885,15 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == REPLACE_DLG) { + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); + HWND hReplaceCombo = ::GetDlgItem(_hSelf, IDREPLACEWITH); + _options._str4Replace = getTextFromCombo(hReplaceCombo, isUnicode); updateCombos(); nppParamInst->_isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_REPLACE + FR_OP_GLOBAL); replaceAllInOpenedDocs(); nppParamInst->_isFindReplacing = false; } @@ -874,11 +904,17 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == REPLACE_DLG) { + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); + HWND hReplaceCombo = ::GetDlgItem(_hSelf, IDREPLACEWITH); + _options._str4Replace = getTextFromCombo(hReplaceCombo, isUnicode); updateCombos(); nppParamInst->_isFindReplacing = true; + if (isMacroRecording) saveInMacro(wParam, FR_OP_REPLACE); (*_ppEditView)->execute(SCI_BEGINUNDOACTION); - int nbReplaced = processAll(ProcessReplaceAll, NULL, NULL); + int nbReplaced = processAll(ProcessReplaceAll, &_options); (*_ppEditView)->execute(SCI_ENDUNDOACTION); nppParamInst->_isFindReplacing = false; @@ -892,7 +928,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP wsprintf(moreInfo, TEXT("%d occurrences were replaced."), nbReplaced); result = moreInfo; } - ::MessageBox(_hSelf, result.c_str(), TEXT("Replace All"), MB_OK); + ::MessageBox(_hMsgParent, result.c_str(), TEXT("Replace All"), MB_OK); } } return TRUE; @@ -901,7 +937,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == FIND_DLG) { - int nbCounted = processAll(ProcessCountAll, NULL, NULL); + int nbCounted = processAll(ProcessCountAll, &_options); generic_string result = TEXT(""); if (nbCounted < 0) @@ -912,7 +948,8 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP wsprintf(moreInfo, TEXT("%d match(es) to occurrence(s)"), nbCounted); result = moreInfo; } - ::MessageBox(_hSelf, result.c_str(), TEXT("Count"), MB_OK); + if (isMacroRecording) saveInMacro(wParam, FR_OP_FIND); + ::MessageBox(_hMsgParent, result.c_str(), TEXT("Count"), MB_OK); } } return TRUE; @@ -921,10 +958,14 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == FIND_DLG) { + bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; + HWND hFindCombo = ::GetDlgItem(_hSelf, IDFINDWHAT); + _options._str2Search = getTextFromCombo(hFindCombo, isUnicode); updateCombo(IDFINDWHAT); + if (isMacroRecording) saveInMacro(wParam, FR_OP_FIND); nppParamInst->_isFindReplacing = true; - int nbMarked = processAll(ProcessMarkAll, NULL, NULL); + int nbMarked = processAll(ProcessMarkAll, &_options); nppParamInst->_isFindReplacing = false; generic_string result = TEXT(""); if (nbMarked < 0) @@ -935,7 +976,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP wsprintf(moreInfo, TEXT("%d match(es) to occurrence(s)"), nbMarked); result = moreInfo; } - ::MessageBox(_hSelf, result.c_str(), TEXT("Mark"), MB_OK); + ::MessageBox(_hMsgParent, result.c_str(), TEXT("Mark"), MB_OK); } } return TRUE; @@ -1007,7 +1048,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDC_PURGE_CHECK : { if (_currentStatus == FIND_DLG) - _doPurge = isCheckedOrNot(IDC_PURGE_CHECK); + _options._doPurge = isCheckedOrNot(IDC_PURGE_CHECK); } return TRUE; @@ -1015,8 +1056,8 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == FIND_DLG) { - _doMarkLine = isCheckedOrNot(IDC_MARKLINE_CHECK); - ::EnableWindow(::GetDlgItem(_hSelf, IDCMARKALL), (_doMarkLine || _doStyleFoundToken)); + _options._doMarkLine = isCheckedOrNot(IDC_MARKLINE_CHECK); + ::EnableWindow(::GetDlgItem(_hSelf, IDCMARKALL), (_options._doMarkLine || _options._doStyleFoundToken)); } } return TRUE; @@ -1025,8 +1066,8 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP { if (_currentStatus == FIND_DLG) { - _doStyleFoundToken = isCheckedOrNot(IDC_STYLEFOUND_CHECK); - ::EnableWindow(::GetDlgItem(_hSelf, IDCMARKALL), (_doMarkLine || _doStyleFoundToken)); + _options._doStyleFoundToken = isCheckedOrNot(IDC_STYLEFOUND_CHECK); + ::EnableWindow(::GetDlgItem(_hSelf, IDCMARKALL), (_options._doMarkLine || _options._doStyleFoundToken)); } } return TRUE; @@ -1034,7 +1075,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDC_IN_SELECTION_CHECK : { if (_currentStatus <= REPLACE_DLG) - _isInSelection = isCheckedOrNot(IDC_IN_SELECTION_CHECK); + _options._isInSelection = isCheckedOrNot(IDC_IN_SELECTION_CHECK); } return TRUE; @@ -1084,7 +1125,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDD_FINDINFILES_RECURSIVE_CHECK : { if (_currentStatus == FINDINFILES_DLG) - findHistory._isFifRecuisive = _isRecursive = isCheckedOrNot(IDD_FINDINFILES_RECURSIVE_CHECK); + findHistory._isFifRecuisive = _options._isRecursive = isCheckedOrNot(IDD_FINDINFILES_RECURSIVE_CHECK); } return TRUE; @@ -1092,7 +1133,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDD_FINDINFILES_INHIDDENDIR_CHECK : { if (_currentStatus == FINDINFILES_DLG) - findHistory._isFifInHiddenFolder = _isInHiddenDir = isCheckedOrNot(IDD_FINDINFILES_INHIDDENDIR_CHECK); + findHistory._isFifInHiddenFolder = _options._isInHiddenDir = isCheckedOrNot(IDD_FINDINFILES_INHIDDENDIR_CHECK); } return TRUE; @@ -1115,7 +1156,7 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP case IDD_FINDINFILES_BROWSE_BUTTON : { if (_currentStatus == FINDINFILES_DLG) - folderBrowser(_hSelf, IDD_FINDINFILES_DIR_COMBO, _directory.c_str()); + folderBrowser(_hSelf, IDD_FINDINFILES_DIR_COMBO, _options._directory.c_str()); } return TRUE; @@ -1131,7 +1172,8 @@ BOOL CALLBACK FindReplaceDlg::run_dlgProc(UINT message, WPARAM wParam, LPARAM lP // return value : // true : the text2find is found // false : the text2find is not found -bool FindReplaceDlg::processFindNext(const TCHAR *txt2find, FindOption *options, FindStatus *oFindStatus) + +bool FindReplaceDlg::processFindNext(const TCHAR *txt2find, const FindOption *options, FindStatus *oFindStatus) { if (oFindStatus) *oFindStatus = FSFound; @@ -1139,7 +1181,7 @@ bool FindReplaceDlg::processFindNext(const TCHAR *txt2find, FindOption *options, if (!txt2find || !txt2find[0]) return false; - FindOption *pOptions = options?options:&_options; + const FindOption *pOptions = options?options:_env; int stringSizeFind = lstrlen(txt2find); TCHAR *pText = new TCHAR[stringSizeFind + 1]; @@ -1220,7 +1262,7 @@ bool FindReplaceDlg::processFindNext(const TCHAR *txt2find, FindOption *options, generic_string msg = TEXT("Can't find the text:\r\n\""); msg += txt2find; msg += TEXT("\""); - ::MessageBox(_hSelf, msg.c_str(), TEXT("Find"), MB_OK); + ::MessageBox(_hMsgParent, msg.c_str(), TEXT("Find"), MB_OK); // if the dialog is not shown, pass the focus to his parent(ie. Notepad++) if (!::IsWindowVisible(_hSelf)) { @@ -1251,12 +1293,12 @@ bool FindReplaceDlg::processFindNext(const TCHAR *txt2find, FindOption *options, // true : the text is replaced, and find the next occurrence // false : the text2find is not found, so the text is NOT replace // || the text is replaced, and do NOT find the next occurrence -bool FindReplaceDlg::processReplace(const TCHAR *txt2find, const TCHAR *txt2replace, FindOption *options) +bool FindReplaceDlg::processReplace(const TCHAR *txt2find, const TCHAR *txt2replace, const FindOption *options) { if (!txt2find || !txt2find[0] || !txt2replace) return false; - FindOption *pOptions = options?options:&_options; + const FindOption *pOptions = options?options:_env; if ((*_ppEditView)->getCurrentBuffer()->isReadOnly()) return false; @@ -1298,18 +1340,19 @@ bool FindReplaceDlg::processReplace(const TCHAR *txt2find, const TCHAR *txt2repl delete [] pTextFind; delete [] pTextReplace; - return processFindNext(txt2find); //after replacing, find the next section for selection + return processFindNext(txt2find, pOptions); //after replacing, find the next section for selection } int FindReplaceDlg::markAll(const TCHAR *txt2find, int styleID) { - _doStyleFoundToken = true; FindOption opt; opt._isMatchCase = true; opt._isWholeWord = false; + opt._doStyleFoundToken = true; + opt._str2Search = txt2find; - int nbFound = processAll(ProcessMarkAllExt, txt2find, NULL, true, NULL, &opt, styleID); + int nbFound = processAll(ProcessMarkAllExt, &opt, true, NULL, styleID); return nbFound; } @@ -1325,15 +1368,17 @@ int FindReplaceDlg::markAll2(const TCHAR *txt2find) */ -int FindReplaceDlg::markAllInc(const TCHAR *txt2find, FindOption *opt) +int FindReplaceDlg::markAllInc(const FindOption *opt) { - int nbFound = processAll(ProcessMarkAll_IncSearch, txt2find, NULL, true, NULL, opt); + int nbFound = processAll(ProcessMarkAll_IncSearch, opt, true); return nbFound; } -int FindReplaceDlg::processAll(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, bool isEntire, const TCHAR *fileName, FindOption *opt, int colourStyleID) +int FindReplaceDlg::processAll(ProcessOperation op, const FindOption *opt, bool isEntire, const TCHAR *fileName, int colourStyleID) { - FindOption *pOptions = opt?opt:&_options; + const FindOption *pOptions = opt?opt:_env; + const TCHAR *txt2find = pOptions->_str2Search.c_str(); + const TCHAR *txt2replace = pOptions->_str4Replace.c_str(); CharacterRange cr = (*_ppEditView)->getSelection(); int docLength = int((*_ppEditView)->execute(SCI_GETLENGTH)); @@ -1367,7 +1412,7 @@ int FindReplaceDlg::processAll(ProcessOperation op, const TCHAR *txt2find, const } //then readjust scope if the selection override is active and allowed - if ((_isInSelection) && ((op == ProcessMarkAll) || ((op == ProcessReplaceAll) && (!isEntire)))) //if selection limiter and either mark all or replace all w/o entire document override + if ((pOptions->_isInSelection) && ((op == ProcessMarkAll) || ((op == ProcessReplaceAll) && (!isEntire)))) //if selection limiter and either mark all or replace all w/o entire document override { startPosition = cr.cpMin; endPosition = cr.cpMax; @@ -1382,7 +1427,7 @@ int FindReplaceDlg::processAll(ProcessOperation op, const TCHAR *txt2find, const return processRange(op, txt2find, txt2replace, startPosition, endPosition, fileName, opt, colourStyleID); } -int FindReplaceDlg::processRange(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, int startRange, int endRange, const TCHAR *fileName, FindOption *opt, int colourStyleID) +int FindReplaceDlg::processRange(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, int startRange, int endRange, const TCHAR *fileName, const FindOption *opt, int colourStyleID) { int nbProcessed = 0; @@ -1398,7 +1443,7 @@ int FindReplaceDlg::processRange(ProcessOperation op, const TCHAR *txt2find, con if (!fileName) fileName = TEXT(""); - FindOption *pOptions = opt?opt:&_options; + const FindOption *pOptions = opt?opt:_env; //bool isUnicode = (*_ppEditView)->getCurrentBuffer()->getUnicodeMode() != uni8Bit; bool isUnicode = ((*_ppEditView)->execute(SCI_GETCODEPAGE) == SC_CP_UTF8); @@ -1459,11 +1504,11 @@ int FindReplaceDlg::processRange(ProcessOperation op, const TCHAR *txt2find, con if (op == ProcessMarkAll && colourStyleID == -1) //if marking, check if purging is needed { - if (_doPurge) { - if (_doMarkLine) + if (_env->_doPurge) { + if (_env->_doMarkLine) (*_ppEditView)->execute(SCI_MARKERDELETEALL, MARK_BOOKMARK); - if (_doStyleFoundToken) + if (_env->_doStyleFoundToken) (*_ppEditView)->clearIndicator(SCE_UNIVERSAL_FOUND_STYLE); } } @@ -1554,13 +1599,13 @@ int FindReplaceDlg::processRange(ProcessOperation op, const TCHAR *txt2find, con case ProcessMarkAll: { - if (_doStyleFoundToken) + if (_env->_doStyleFoundToken) { (*_ppEditView)->execute(SCI_SETINDICATORCURRENT, SCE_UNIVERSAL_FOUND_STYLE); (*_ppEditView)->execute(SCI_INDICATORFILLRANGE, targetStart, foundTextLen); } - if (_doMarkLine) + if (_env->_doMarkLine) { int lineNumber = (*_ppEditView)->execute(SCI_LINEFROMPOSITION, targetStart); int state = (*_ppEditView)->execute(SCI_MARKERGET, lineNumber); @@ -1807,19 +1852,206 @@ void FindReplaceDlg::enableFindInFilesControls(bool isEnable) void FindReplaceDlg::getPatterns(vector & patternVect) { - cutString(_filters.c_str(), patternVect); + cutString(_env->_filters.c_str(), patternVect); +} + +void FindReplaceDlg::saveInMacro(int cmd, int cmdType) +{ + int booleans = 0; + ::SendMessage(_hParent, WM_FRSAVE_INT, IDC_FRCOMMAND_INIT, 0); + ::SendMessage(_hParent, WM_FRSAVE_STR, IDFINDWHAT, reinterpret_cast(_options._str2Search.c_str())); + booleans |= _options._isWholeWord?IDF_WHOLEWORD:0; + booleans |= _options._isMatchCase?IDF_MATCHCASE:0; + ::SendMessage(_hParent, WM_FRSAVE_INT, IDNORMAL, _options._searchType); + if (cmd == IDCMARKALL) + { + booleans |= _options._doPurge?IDF_PURGE_CHECK:0; + booleans |= _options._doMarkLine?IDF_MARKLINE_CHECK:0; + booleans |= _options._doStyleFoundToken?IDF_STYLEFOUND_CHECK:0; + } + if (cmdType & FR_OP_REPLACE) + ::SendMessage(_hParent, WM_FRSAVE_STR, IDREPLACEWITH, (LPARAM)_options._str4Replace.c_str()); + if (cmdType & FR_OP_FIF) + { + ::SendMessage(_hParent, WM_FRSAVE_STR, IDD_FINDINFILES_DIR_COMBO, (LPARAM)_options._directory.c_str()); + ::SendMessage(_hParent, WM_FRSAVE_STR, IDD_FINDINFILES_FILTERS_COMBO, (LPARAM)_options._filters.c_str()); + booleans |= _options._isRecursive?IDF_FINDINFILES_RECURSIVE_CHECK:0; + booleans |= _options._isInHiddenDir?IDF_FINDINFILES_INHIDDENDIR_CHECK:0; + } + else if (!(cmdType & FR_OP_GLOBAL)) + { + booleans |= _options._isInSelection?IDF_IN_SELECTION_CHECK:0; + booleans |= _options._isWrapAround?IDF_WRAP:0; + booleans |= _options._whichDirection?IDF_WHICH_DIRECTION:0; + } + ::SendMessage(_hParent, WM_FRSAVE_INT, IDC_FRCOMMAND_BOOLEANS, booleans); + ::SendMessage(_hParent, WM_FRSAVE_INT, IDC_FRCOMMAND_EXEC, cmd); +} + +void FindReplaceDlg::execSavedCommand(int cmd, int intValue, generic_string stringValue) +{ + switch(cmd) + { + case IDC_FRCOMMAND_INIT: + _env = new FindOption; + _hMsgParent = _hParent; + break; + case IDFINDWHAT: + _env->_str2Search = stringValue; + break; + case IDC_FRCOMMAND_BOOLEANS: + _env->_isWholeWord = ((intValue & IDF_WHOLEWORD)> 0); + _env->_isMatchCase = ((intValue & IDF_MATCHCASE)> 0); + _env->_isRecursive = ((intValue & IDF_FINDINFILES_RECURSIVE_CHECK)> 0); + _env->_isInHiddenDir = ((intValue & IDF_FINDINFILES_INHIDDENDIR_CHECK)> 0); + _env->_doPurge = ((intValue & IDF_PURGE_CHECK)> 0); + _env->_doMarkLine = ((intValue & IDF_MARKLINE_CHECK)> 0); + _env->_doStyleFoundToken = ((intValue & IDF_STYLEFOUND_CHECK)> 0); + _env->_isInSelection = ((intValue & IDF_IN_SELECTION_CHECK)> 0); + _env->_isWrapAround = ((intValue & IDF_WRAP)> 0); + _env->_whichDirection = ((intValue & IDF_WHICH_DIRECTION)> 0); + break; + case IDNORMAL: + _env->_searchType = (SearchType)intValue; + break; + case IDREPLACEWITH: + _env->_str4Replace = stringValue; + break; + case IDD_FINDINFILES_DIR_COMBO: + _env->_directory = stringValue; + break; + case IDD_FINDINFILES_FILTERS_COMBO: + _env->_filters = stringValue; + break; + case IDC_FRCOMMAND_EXEC: + { + NppParameters *nppParamInst = NppParameters::getInstance(); + switch(intValue) + { + case IDOK: + nppParamInst->_isFindReplacing = true; + processFindNext(_env->_str2Search.c_str()); + nppParamInst->_isFindReplacing = false; + break; + case IDREPLACE: + nppParamInst->_isFindReplacing = true; + processReplace(_env->_str2Search.c_str(), _env->_str4Replace.c_str(), _env); + nppParamInst->_isFindReplacing = false; + break; + case IDC_FINDALL_OPENEDFILES: + nppParamInst->_isFindReplacing = true; + findAllIn(ALL_OPEN_DOCS); + nppParamInst->_isFindReplacing = false; + break; + case IDC_FINDALL_CURRENTFILE: + nppParamInst->_isFindReplacing = true; + findAllIn(FILES_IN_DIR); + nppParamInst->_isFindReplacing = false; + break; + case IDC_REPLACE_OPENEDFILES : + nppParamInst->_isFindReplacing = true; + replaceAllInOpenedDocs(); + nppParamInst->_isFindReplacing = false; + break; + case IDD_FINDINFILES_FIND_BUTTON : + { + nppParamInst->_isFindReplacing = true; + findAllIn(FILES_IN_DIR); + nppParamInst->_isFindReplacing = false; + break; + } + case IDD_FINDINFILES_REPLACEINFILES : + { + generic_string msg = TEXT("Are you sure you want to replace all occurances in :\r"); + msg += _env->_directory; + msg += TEXT("\rfor file type : "); + msg += (_env->_filters[0])?_env->_filters:TEXT("*.*"); + + if (::MessageBox(_hMsgParent, msg.c_str(), TEXT("Are you sure?"), MB_OKCANCEL) == IDOK) + { + nppParamInst->_isFindReplacing = true; + ::SendMessage(_hParent, WM_REPLACEINFILES, 0, 0); + nppParamInst->_isFindReplacing = false; + } + break; + } + case IDREPLACEALL : + { + nppParamInst->_isFindReplacing = true; + (*_ppEditView)->execute(SCI_BEGINUNDOACTION); + int nbReplaced = processAll(ProcessReplaceAll, _env); + (*_ppEditView)->execute(SCI_ENDUNDOACTION); + nppParamInst->_isFindReplacing = false; + + generic_string result = TEXT(""); + + if (nbReplaced < 0) + result = TEXT("The regular expression to search is formed badly"); + else + { + TCHAR moreInfo[64]; + wsprintf(moreInfo, TEXT("%d occurrences were replaced."), nbReplaced); + result = moreInfo; + } + ::MessageBox(_hMsgParent, result.c_str(), TEXT("Replace All"), MB_OK); + break; + } + case IDCCOUNTALL : + { + int nbCounted = processAll(ProcessCountAll, _env); + generic_string result = TEXT(""); + + if (nbCounted < 0) + result = TEXT("The regular expression to search is formed badly.\r\nIs it resulting in nothing?"); + else + { + TCHAR moreInfo[128]; + wsprintf(moreInfo, TEXT("%d match(es) to occurrence(s)"), nbCounted); + result = moreInfo; + } + ::MessageBox(_hMsgParent, result.c_str(), TEXT("Count"), MB_OK); + break; + } + case IDCMARKALL: + { + nppParamInst->_isFindReplacing = true; + int nbMarked = processAll(ProcessMarkAll, _env); + nppParamInst->_isFindReplacing = false; + generic_string result = TEXT(""); + if (nbMarked < 0) + result = TEXT("The regular expression to search is formed badly.\r\nIs it resulting in nothing?"); + else + { + TCHAR moreInfo[128]; + wsprintf(moreInfo, TEXT("%d match(es) to occurrence(s)"), nbMarked); + result = moreInfo; + } + ::MessageBox(_hMsgParent, result.c_str(), TEXT("Mark"), MB_OK); + break; + } + default: + throw std::runtime_error("Internal error: unknown saved command!"); + } + _hMsgParent = _hSelf; + delete _env; + _env = &_options; + break; + } + default: + throw std::runtime_error("Internal error: unknown SnR command!"); + } } void FindReplaceDlg::setFindInFilesDirFilter(const TCHAR *dir, const TCHAR *filters) { if (dir) { - _directory = dir; + _options._directory = dir; ::SetDlgItemText(_hSelf, IDD_FINDINFILES_DIR_COMBO, dir); } if (filters) { - _filters = filters; + _options._filters = filters; ::SetDlgItemText(_hSelf, IDD_FINDINFILES_FILTERS_COMBO, filters); } } @@ -1830,13 +2062,13 @@ void FindReplaceDlg::initOptionsFromDlg() _options._isMatchCase = isCheckedOrNot(IDMATCHCASE); _options._searchType = isCheckedOrNot(IDREGEXP)?FindRegex:isCheckedOrNot(IDEXTENDED)?FindExtended:FindNormal; _options._isWrapAround = isCheckedOrNot(IDWRAP); - _isInSelection = isCheckedOrNot(IDC_IN_SELECTION_CHECK); + _options._isInSelection = isCheckedOrNot(IDC_IN_SELECTION_CHECK); - _doPurge = isCheckedOrNot(IDC_PURGE_CHECK); - _doMarkLine = isCheckedOrNot(IDC_MARKLINE_CHECK); - _doStyleFoundToken = isCheckedOrNot(IDC_STYLEFOUND_CHECK); + _options._doPurge = isCheckedOrNot(IDC_PURGE_CHECK); + _options._doMarkLine = isCheckedOrNot(IDC_MARKLINE_CHECK); + _options._doStyleFoundToken = isCheckedOrNot(IDC_STYLEFOUND_CHECK); - ::EnableWindow(::GetDlgItem(_hSelf, IDCMARKALL), (_doMarkLine || _doStyleFoundToken)); + ::EnableWindow(::GetDlgItem(_hSelf, IDCMARKALL), (_options._doMarkLine || _options._doStyleFoundToken)); } void FindReplaceDlg::doDialog(DIALOG_TYPE whichType, bool isRTL, bool toShow) @@ -1935,7 +2167,6 @@ void FindReplaceDlg::combo2ExtendedMode(int comboID) } } - void Finder::addSearchLine(const TCHAR *searchName) { generic_string str = TEXT("Search \""); @@ -2375,7 +2606,8 @@ void FindIncrementDlg::markSelectedTextInc(bool enable, FindOption *opt) TCHAR text2Find[FINDREPLACE_MAXLENGTH]; (*(_pFRDlg->_ppEditView))->getGenericSelectedText(text2Find, FINDREPLACE_MAXLENGTH, false); //do not expand selection (false) - _pFRDlg->markAllInc(text2Find, opt); + opt->_str2Search = text2Find; + _pFRDlg->markAllInc(opt); } void FindIncrementDlg::setFindStatus(FindStatus iStatus) diff --git a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h index cde9c761f..8bdeabafc 100644 --- a/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h +++ b/PowerEditor/src/ScitillaComponent/FindReplaceDlg.h @@ -61,15 +61,29 @@ enum SearchIncrementalType { NotIncremental, FirstIncremental, NextIncremental } enum SearchType { FindNormal, FindExtended, FindRegex }; enum ProcessOperation { ProcessFindAll, ProcessReplaceAll, ProcessCountAll, ProcessMarkAll, ProcessMarkAll_2, ProcessMarkAll_IncSearch, ProcessMarkAllExt }; -struct FindOption { +struct FindOption +{ bool _isWholeWord; bool _isMatchCase; bool _isWrapAround; bool _whichDirection; SearchIncrementalType _incrementalType; SearchType _searchType; - FindOption() :_isWholeWord(true), _isMatchCase(true), _searchType(FindNormal),\ - _isWrapAround(true), _whichDirection(DIR_DOWN), _incrementalType(NotIncremental){}; + bool _doPurge; + bool _doMarkLine; + bool _doStyleFoundToken; + bool _isInSelection; + generic_string _str2Search; + generic_string _str4Replace; + generic_string _filters; + generic_string _directory; + bool _isRecursive; + bool _isInHiddenDir; + FindOption() : _isWholeWord(true), _isMatchCase(true), _searchType(FindNormal),\ + _isWrapAround(true), _whichDirection(DIR_DOWN), _incrementalType(NotIncremental), + _doPurge(false), _doMarkLine(false), _doStyleFoundToken(false), + _isInSelection(false), _isRecursive(false), _isInHiddenDir(false), + _filters(TEXT("")), _directory(TEXT("")) {}; }; //This class contains generic search functions as static functions for easy access @@ -77,7 +91,7 @@ class Searching { public: static int convertExtendedToString(const TCHAR * query, TCHAR * result, int length); static TargetRange t; - static int buildSearchFlags(FindOption * option) { + static int buildSearchFlags(const FindOption * option) { return (option->_isWholeWord ? SCFIND_WHOLEWORD : 0) | (option->_isMatchCase ? SCFIND_MATCHCASE : 0) | (option->_searchType == FindRegex ? SCFIND_REGEXP|SCFIND_POSIX : 0); @@ -157,10 +171,13 @@ class FindReplaceDlg : public StaticDialog { friend class FindIncrementDlg; public : - FindReplaceDlg() : StaticDialog(), _pFinder(NULL), _isRTL(false), _isRecursive(true),_isInHiddenDir(false),\ + static FindOption _options; + static FindOption* _env; + FindReplaceDlg() : StaticDialog(), _pFinder(NULL), _isRTL(false),\ _fileNameLenMax(1024) { _uniFileName = new char[(_fileNameLenMax + 3) * 2]; _winVer = (NppParameters::getInstance())->getWinVersion(); + _env = &_options; }; ~FindReplaceDlg(); @@ -169,6 +186,7 @@ public : if (!ppEditView) throw std::runtime_error("FindIncrementDlg::init : ppEditView is null."); _ppEditView = ppEditView; + _hMsgParent = _hSelf; }; virtual void create(int dialogID, bool isRTL = false); @@ -176,16 +194,17 @@ public : void initOptionsFromDlg(); void doDialog(DIALOG_TYPE whichType, bool isRTL = false, bool toShow = true); - bool processFindNext(const TCHAR *txt2find, FindOption *options = NULL, FindStatus *oFindStatus = NULL); - bool processReplace(const TCHAR *txt2find, const TCHAR *txt2replace, FindOption *options = NULL); + bool processFindNext(const TCHAR *txt2find, const FindOption *options = NULL, FindStatus *oFindStatus = NULL); + bool processReplace(const TCHAR *txt2find, const TCHAR *txt2replace, const FindOption *options = NULL); int markAll(const TCHAR *txt2find, int styleID); //int markAll2(const TCHAR *str2find); - int markAllInc(const TCHAR *str2find, FindOption *opt); + int markAllInc(const FindOption *opt); - int processAll(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, bool isEntire = false, const TCHAR *fileName = NULL, FindOption *opt = NULL, int colourStyleID = -1); - int processRange(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, int startRange, int endRange, const TCHAR *fileName = NULL, FindOption *opt = NULL, int colourStyleID = -1); + int processAll(ProcessOperation op, const FindOption *opt, bool isEntire = false, const TCHAR *fileName = NULL, int colourStyleID = -1); +// int processAll(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, bool isEntire = false, const TCHAR *fileName = NULL, const FindOption *opt = NULL, int colourStyleID = -1); + int processRange(ProcessOperation op, const TCHAR *txt2find, const TCHAR *txt2replace, int startRange, int endRange, const TCHAR *fileName = NULL, const FindOption *opt = NULL, int colourStyleID = -1); void replaceAllInOpenedDocs(); void findAllIn(InWhat op); void setSearchText(TCHAR * txt2find); @@ -195,7 +214,7 @@ public : void putFindResult(int result) { _findAllResult = result; }; - const TCHAR * getDir2Search() const {return _directory.c_str();}; + const TCHAR * getDir2Search() const {return _env->_directory.c_str();}; void getPatterns(vector & patternVect); @@ -206,14 +225,14 @@ public : void setFindInFilesDirFilter(const TCHAR *dir, const TCHAR *filters); generic_string getText2search() const { - return getTextFromCombo(::GetDlgItem(_hSelf, IDFINDWHAT)); + return _env->_str2Search; }; - const generic_string & getFilters() const {return _filters;}; - const generic_string & getDirectory() const {return _directory;}; - const FindOption & getCurrentOptions() const {return _options;}; - bool isRecursive() const { return _isRecursive; }; - bool isInHiddenDir() const { return _isInHiddenDir; }; + const generic_string & getFilters() const {return _env->_filters;}; + const generic_string & getDirectory() const {return _env->_directory;}; + const FindOption & getCurrentOptions() const {return *_env;}; + bool isRecursive() const { return _env->_isRecursive; }; + bool isInHiddenDir() const { return _env->_isInHiddenDir; }; void saveFindHistory(); void changeTabName(DIALOG_TYPE index, const TCHAR *name2change) { TCITEM tie; @@ -252,7 +271,8 @@ public : { _pFinder->setFinderStyle(); } - }; + } + void execSavedCommand(int cmd, int intValue, generic_string stringValue); protected : virtual BOOL CALLBACK run_dlgProc(UINT message, WPARAM wParam, LPARAM lParam); @@ -266,15 +286,8 @@ protected : void combo2ExtendedMode(int comboID); private : + DIALOG_TYPE _currentStatus; - FindOption _options; - - bool _doPurge; - bool _doMarkLine; - bool _doStyleFoundToken; - bool _isInSelection; - - RECT _findClosePos, _replaceClosePos, _findInFilesClosePos; ScintillaEditView **_ppEditView; @@ -284,11 +297,6 @@ private : int _findAllResult; TCHAR _findAllResultStr[1024]; - generic_string _filters; - generic_string _directory; - bool _isRecursive; - bool _isInHiddenDir; - int _fileNameLenMax; char *_uniFileName; @@ -322,6 +330,12 @@ private : void fillFindHistory(); void fillComboHistory(int id, const std::vector & strings); int saveComboHistory(int id, int maxcount, vector & strings); + static const int FR_OP_FIND = 1; + static const int FR_OP_REPLACE = 2; + static const int FR_OP_FIF = 4; + static const int FR_OP_GLOBAL = 8; + void saveInMacro(int cmd, int cmdType); + HWND _hMsgParent; }; //FindIncrementDlg: incremental search dialog, docked in rebar diff --git a/PowerEditor/src/ScitillaComponent/FindReplaceDlg_rc.h b/PowerEditor/src/ScitillaComponent/FindReplaceDlg_rc.h index 643405011..2725bb354 100644 --- a/PowerEditor/src/ScitillaComponent/FindReplaceDlg_rc.h +++ b/PowerEditor/src/ScitillaComponent/FindReplaceDlg_rc.h @@ -22,7 +22,9 @@ #define IDFINDWHAT 1601 #define IDREPLACEWITH 1602 #define IDWHOLEWORD 1603 +#define IDF_WHOLEWORD 1 #define IDMATCHCASE 1604 +#define IDF_MATCHCASE 2 #define IDC_MODE_STATIC 1624 #define IDNORMAL 1625 @@ -31,6 +33,7 @@ #define IDREGEXP 1605 #define IDWRAP 1606 +#define IDF_WRAP 256 #define IDUNSLASH 1607 #define IDREPLACE 1608 #define IDREPLACEALL 1609 @@ -38,11 +41,15 @@ #define ID_STATICTEXT_REPLACE 1611 #define IDDIRECTIONUP 1612 #define IDDIRECTIONDOWN 1613 +#define IDF_WHICH_DIRECTION 512 #define IDCCOUNTALL 1614 #define IDCMARKALL 1615 #define IDC_MARKLINE_CHECK 1616 +#define IDF_MARKLINE_CHECK 16 #define IDC_STYLEFOUND_CHECK 1617 +#define IDF_STYLEFOUND_CHECK 8 #define IDC_PURGE_CHECK 1618 +#define IDF_PURGE_CHECK 4 #define IDC_FINDALL_STATIC 1619 #define IDFINDWHAT_STATIC 1620 #define IDC_DIR_STATIC 1621 @@ -55,6 +62,7 @@ //#define IDC_OPENED_FILES_RADIO 1630 //#define IDC_FILES_RADIO 1631 #define IDC_IN_SELECTION_CHECK 1632 +#define IDF_IN_SELECTION_CHECK 128 #define IDC_CLEAR_ALL 1633 #define IDC_REPLACEINSELECTION 1634 #define IDC_REPLACE_OPENEDFILES 1635 @@ -74,7 +82,9 @@ #define IDD_FINDINFILES_FIND_BUTTON 1656 #define IDD_FINDINFILES_GOBACK_BUTTON 1657 #define IDD_FINDINFILES_RECURSIVE_CHECK 1658 +#define IDF_FINDINFILES_RECURSIVE_CHECK 32 #define IDD_FINDINFILES_INHIDDENDIR_CHECK 1659 +#define IDF_FINDINFILES_INHIDDENDIR_CHECK 64 #define IDD_FINDINFILES_REPLACEINFILES 1660 #define IDD_FINDINFILES_FOLDERFOLLOWSDOC_CHECK 1661 @@ -93,4 +103,8 @@ #define IDC_TRANSPARENT_LOSSFOCUS_RADIO 1687 #define IDC_TRANSPARENT_ALWAYS_RADIO 1688 +#define IDC_FRCOMMAND_INIT 1700 +#define IDC_FRCOMMAND_EXEC 1701 +#define IDC_FRCOMMAND_BOOLEANS 1702 + #endif //FINDREPLACE_DLG_H diff --git a/PowerEditor/src/ScitillaComponent/ScintillaEditView.h b/PowerEditor/src/ScitillaComponent/ScintillaEditView.h index 353cbb229..268641b02 100644 --- a/PowerEditor/src/ScitillaComponent/ScintillaEditView.h +++ b/PowerEditor/src/ScitillaComponent/ScintillaEditView.h @@ -86,6 +86,8 @@ typedef void * SCINTILLA_PTR; #define WM_FINDINFILES (SCINTILLA_USER + 9) #define WM_REPLACEINFILES (SCINTILLA_USER + 10) #define WM_FINDALL_INCURRENTDOC (SCINTILLA_USER + 11) +#define WM_FRSAVE_INT (SCINTILLA_USER + 12) +#define WM_FRSAVE_STR (SCINTILLA_USER + 13) const int NB_FOLDER_STATE = 7; diff --git a/PowerEditor/src/WinControls/shortcut/RunMacroDlg.cpp b/PowerEditor/src/WinControls/shortcut/RunMacroDlg.cpp index 0c8a8baf4..2de45591a 100644 --- a/PowerEditor/src/WinControls/shortcut/RunMacroDlg.cpp +++ b/PowerEditor/src/WinControls/shortcut/RunMacroDlg.cpp @@ -31,7 +31,7 @@ void RunMacroDlg::initMacroList() ::SendDlgItemMessage(_hSelf, IDC_MACRO_COMBO, CB_RESETCONTENT, 0, 0); - if (::SendMessage(_hParent, WM_ISCURRENTMACRORECORDED, 0, 0)) + if (::SendMessage(_hParent, WM_GETCURRENTMACROSTATUS, 0, 0) == MACRO_RECORDING_HAS_STOPPED) ::SendDlgItemMessage(_hSelf, IDC_MACRO_COMBO, CB_ADDSTRING, 0, (LPARAM)TEXT("Current recorded macro")); for (size_t i = 0 ; i < macroList.size() ; i++) @@ -134,6 +134,6 @@ void RunMacroDlg::check(int id) int RunMacroDlg::getMacro2Exec() const { - bool isCurMacroPresent = ::SendMessage(_hParent, WM_ISCURRENTMACRORECORDED, 0, 0) == TRUE; + bool isCurMacroPresent = ::SendMessage(_hParent, WM_GETCURRENTMACROSTATUS, 0, 0) == MACRO_RECORDING_HAS_STOPPED; return isCurMacroPresent?(m_macroIndex - 1):m_macroIndex; } diff --git a/PowerEditor/src/WinControls/shortcut/shortcut.cpp b/PowerEditor/src/WinControls/shortcut/shortcut.cpp index b50da67c7..812e0651f 100644 --- a/PowerEditor/src/WinControls/shortcut/shortcut.cpp +++ b/PowerEditor/src/WinControls/shortcut/shortcut.cpp @@ -558,6 +558,10 @@ recordedMacroStep::recordedMacroStep(int iMessage, long wParam, long lParam) case SCI_STYLESETFONT : case SCI_SEARCHNEXT : case SCI_SEARCHPREV : + case IDFINDWHAT: + case IDREPLACEWITH: + case IDD_FINDINFILES_DIR_COMBO: + case IDD_FINDINFILES_FILTERS_COMBO: sParameter = *reinterpret_cast(lParameter); MacroType = mtUseSParameter; lParameter = 0; diff --git a/PowerEditor/src/WinControls/shortcut/shortcut.h b/PowerEditor/src/WinControls/shortcut/shortcut.h index e6fa27445..c651eb0ef 100644 --- a/PowerEditor/src/WinControls/shortcut/shortcut.h +++ b/PowerEditor/src/WinControls/shortcut/shortcut.h @@ -260,7 +260,7 @@ class Window; class ScintillaEditView; struct recordedMacroStep { - enum MacroTypeIndex {mtUseLParameter, mtUseSParameter, mtMenuCommand}; + enum MacroTypeIndex {mtUseLParameter, mtUseSParameter, mtMenuCommand, mtSavedSnR}; int message; long wParameter; @@ -271,13 +271,15 @@ struct recordedMacroStep { recordedMacroStep(int iMessage, long wParam, long lParam); recordedMacroStep(int iCommandID) : message(0), wParameter(iCommandID), lParameter(0), MacroType(mtMenuCommand) {}; - recordedMacroStep(int type, int iMessage, long wParam, long lParam, const TCHAR *sParam) + recordedMacroStep(int iMessage, long wParam, long lParam, const TCHAR *sParam, int type = mtSavedSnR) : message(iMessage), wParameter(wParam), lParameter(lParam), MacroType(MacroTypeIndex(type)){ - sParameter = *reinterpret_cast(sParam); + sParameter = (sParam)?generic_string(sParam):TEXT(""); }; + bool isValid() const { return true; }; + bool isPlayable() const {return MacroType <= mtMenuCommand;}; void PlayBack(Window* pNotepad, ScintillaEditView *pEditView); }; diff --git a/PowerEditor/src/resource.h b/PowerEditor/src/resource.h index 1f6a3e420..49d27c72f 100644 --- a/PowerEditor/src/resource.h +++ b/PowerEditor/src/resource.h @@ -367,7 +367,7 @@ #define MACRO_USER (WM_USER + 4000) - #define WM_ISCURRENTMACRORECORDED (MACRO_USER + 01) + #define WM_GETCURRENTMACROSTATUS (MACRO_USER + 01) #define WM_MACRODLGRUNMACRO (MACRO_USER + 02)