[EU-FOSSA] Fix crash issue due to heap overflow in clipboardHistoryPanel.cpp
When the amount of clipboard data is too important, it makes crash of function WideCharToMultiByte (win32 API). The remedy is to capture this error to prevent Notepad++ from crash.
This commit is contained in:
parent
694415f8af
commit
5b1f530204
@ -248,16 +248,24 @@ INT_PTR CALLBACK ClipboardHistoryPanel::run_dlgProc(UINT message, WPARAM wParam,
|
|||||||
codepage = SC_CP_UTF8;
|
codepage = SC_CP_UTF8;
|
||||||
|
|
||||||
ByteArray ba(_clipboardDataVector[i]);
|
ByteArray ba(_clipboardDataVector[i]);
|
||||||
|
char* c = nullptr;
|
||||||
|
try {
|
||||||
|
int nbChar = WideCharToMultiByte(codepage, 0, (wchar_t *)ba.getPointer(), static_cast<int32_t>(ba.getLength()), NULL, 0, NULL, NULL);
|
||||||
|
|
||||||
int nbChar = WideCharToMultiByte(codepage, 0, (wchar_t *)ba.getPointer(), static_cast<int32_t>(ba.getLength()), NULL, 0, NULL, NULL);
|
c = new char[nbChar + 1];
|
||||||
|
WideCharToMultiByte(codepage, 0, (wchar_t *)ba.getPointer(), static_cast<int32_t>(ba.getLength()), c, nbChar + 1, NULL, NULL);
|
||||||
|
|
||||||
char *c = new char[nbChar+1];
|
(*_ppEditView)->execute(SCI_REPLACESEL, 0, reinterpret_cast<LPARAM>(""));
|
||||||
WideCharToMultiByte(codepage, 0, (wchar_t *)ba.getPointer(), static_cast<int32_t>(ba.getLength()), c, nbChar + 1, NULL, NULL);
|
(*_ppEditView)->execute(SCI_ADDTEXT, strlen(c), reinterpret_cast<LPARAM>(c));
|
||||||
|
(*_ppEditView)->getFocus();
|
||||||
(*_ppEditView)->execute(SCI_REPLACESEL, 0, reinterpret_cast<LPARAM>(""));
|
delete[] c;
|
||||||
(*_ppEditView)->execute(SCI_ADDTEXT, strlen(c), reinterpret_cast<LPARAM>(c));
|
}
|
||||||
(*_ppEditView)->getFocus();
|
catch (...)
|
||||||
delete [] c;
|
{
|
||||||
|
MessageBox(_hSelf, TEXT("Cannot process this clipboard data in the history:\nThe data is too large to be treated."), TEXT("Clipboard problem"), MB_OK | MB_APPLMODAL);
|
||||||
|
if (c)
|
||||||
|
delete[] c;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
Loading…
Reference in New Issue
Block a user