Make hard-coded shortcut "Shift-DEL" be abled to be disabled

In order to disable the hard-coded shortcut "Shift-DEL" ability (new feature introduced in v8.6) which delete current line while no selection, users must add an empty file named "disableHardCodedShiftDelete.xml", in "%APPDATA%\Notepad++\" directory (or in the Notepad++ installed directory in portable mode) to prevent this behaviour.

Fix #14470, close #14481
This commit is contained in:
Don Ho 2023-12-13 15:51:59 +01:00
parent aef0438180
commit 53b5055118
3 changed files with 31 additions and 5 deletions

View File

@ -1593,7 +1593,11 @@ bool NppParameters::load()
std::wstring filePath, filePath2, issueFileName; std::wstring filePath, filePath2, issueFileName;
//-------------------------------------------------------------//
// nppLogNetworkDriveIssue.xml //
// This empty xml file is optional - user adds this empty file //
// It's for debugging use only //
//-------------------------------------------------------------//
filePath = _nppPath; filePath = _nppPath;
issueFileName = nppLogNetworkDriveIssue; issueFileName = nppLogNetworkDriveIssue;
issueFileName += TEXT(".xml"); issueFileName += TEXT(".xml");
@ -1606,6 +1610,11 @@ bool NppParameters::load()
_doNppLogNetworkDriveIssue = (PathFileExists(filePath2.c_str()) == TRUE); _doNppLogNetworkDriveIssue = (PathFileExists(filePath2.c_str()) == TRUE);
} }
//-------------------------------------------------------------//
// nppLogNulContentCorruptionIssue.xml //
// This empty xml file is optional - user adds this empty file //
// It's for debugging use only //
//-------------------------------------------------------------//
filePath = _nppPath; filePath = _nppPath;
issueFileName = nppLogNulContentCorruptionIssue; issueFileName = nppLogNulContentCorruptionIssue;
issueFileName += TEXT(".xml"); issueFileName += TEXT(".xml");
@ -1642,14 +1651,28 @@ bool NppParameters::load()
// manually in order to prevent Notepad++ transform column // // manually in order to prevent Notepad++ transform column //
// selection into multi-select. // // selection into multi-select. //
//-------------------------------------------------------------// //-------------------------------------------------------------//
std::wstring enableNoColumn2MultiSelectPath = _userPath; std::wstring disableColumn2MultiSelectPath = _userPath;
pathAppend(enableNoColumn2MultiSelectPath, TEXT("noColumnToMultiSelect.xml")); pathAppend(disableColumn2MultiSelectPath, TEXT("noColumnToMultiSelect.xml"));
if (PathFileExists(enableNoColumn2MultiSelectPath.c_str())) if (PathFileExists(disableColumn2MultiSelectPath.c_str()))
{ {
_column2MultiSelect = false; _column2MultiSelect = false;
} }
//-------------------------------------------------------------//
// disableHardCodedShiftDelete.xml //
// This empty xml file is optional - user adds this empty file //
// manually in order to prevent hard coded Shift-DEL shortcut //
// delete whole line while no selection. //
//-------------------------------------------------------------//
std::wstring disableHardCodedShiftDeletePath = _userPath;
pathAppend(disableHardCodedShiftDeletePath, TEXT("disableHardCodedShiftDelete.xml"));
if (PathFileExists(disableHardCodedShiftDeletePath.c_str()))
{
_useHardCodedShiftDelete = false;
}
return isAllLaoded; return isAllLaoded;
} }

View File

@ -1878,6 +1878,7 @@ public:
bool isSelectFgColorEnabled() const { return _isSelectFgColorEnabled; }; bool isSelectFgColorEnabled() const { return _isSelectFgColorEnabled; };
bool isRegForOSAppRestartDisabled() const { return _isRegForOSAppRestartDisabled; }; bool isRegForOSAppRestartDisabled() const { return _isRegForOSAppRestartDisabled; };
bool doColumn2MultiSelect() const { return _column2MultiSelect; }; bool doColumn2MultiSelect() const { return _column2MultiSelect; };
bool useHardCodedShiftDelete() const { return _useHardCodedShiftDelete; };
private: private:
bool _isAnyShortcutModified = false; bool _isAnyShortcutModified = false;
@ -1946,6 +1947,7 @@ private:
bool _isSelectFgColorEnabled = false; bool _isSelectFgColorEnabled = false;
bool _isRegForOSAppRestartDisabled = false; bool _isRegForOSAppRestartDisabled = false;
bool _column2MultiSelect = true; bool _column2MultiSelect = true;
bool _useHardCodedShiftDelete = true;
bool _doNppLogNetworkDriveIssue = false; bool _doNppLogNetworkDriveIssue = false;
bool _doNppLogNulContentCorruptionIssue = false; bool _doNppLogNulContentCorruptionIssue = false;

View File

@ -525,13 +525,14 @@ LRESULT ScintillaEditView::scintillaNew_Proc(HWND hwnd, UINT Message, WPARAM wPa
SHORT shift = GetKeyState(VK_SHIFT); SHORT shift = GetKeyState(VK_SHIFT);
bool isColumnSelection = (execute(SCI_GETSELECTIONMODE) == SC_SEL_RECTANGLE) || (execute(SCI_GETSELECTIONMODE) == SC_SEL_THIN); bool isColumnSelection = (execute(SCI_GETSELECTIONMODE) == SC_SEL_RECTANGLE) || (execute(SCI_GETSELECTIONMODE) == SC_SEL_THIN);
bool column2MultSelect = (NppParameters::getInstance()).doColumn2MultiSelect(); bool column2MultSelect = (NppParameters::getInstance()).doColumn2MultiSelect();
bool useHardCodedShiftDelete = (NppParameters::getInstance()).useHardCodedShiftDelete();
if (wParam == VK_DELETE) if (wParam == VK_DELETE)
{ {
// 1 shortcut: // 1 shortcut:
// Shift + Delete: without selected text, it will delete the whole line. // Shift + Delete: without selected text, it will delete the whole line.
// //
if ((shift & 0x8000) && !(ctrl & 0x8000) && !(alt & 0x8000) && !hasSelection()) // Shift-DEL & no selection if ((shift & 0x8000) && !(ctrl & 0x8000) && !(alt & 0x8000) && !hasSelection() && useHardCodedShiftDelete) // Shift-DEL & no selection
{ {
execute(SCI_LINEDELETE); execute(SCI_LINEDELETE);
return TRUE; return TRUE;