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:
parent
aef0438180
commit
53b5055118
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue