Added checks to encoding conversion to avoid crash
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@51458 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -974,6 +974,9 @@ wxTextCtrl::StreamIn(const wxString& value,
|
|||||||
|
|
||||||
const size_t len = conv.MB2WC(NULL, value.mb_str(), value.length());
|
const size_t len = conv.MB2WC(NULL, value.mb_str(), value.length());
|
||||||
|
|
||||||
|
if (len == wxCONV_FAILED)
|
||||||
|
return false;
|
||||||
|
|
||||||
#if wxUSE_WCHAR_T
|
#if wxUSE_WCHAR_T
|
||||||
wxWCharBuffer wchBuf(len);
|
wxWCharBuffer wchBuf(len);
|
||||||
wchar_t *wpc = wchBuf.data();
|
wchar_t *wpc = wchBuf.data();
|
||||||
@@ -1066,7 +1069,8 @@ wxTextCtrl::StreamOut(wxFontEncoding encoding, bool selectionOnly) const
|
|||||||
// conversion but what else can we do)
|
// conversion but what else can we do)
|
||||||
wxCSConv conv(encoding);
|
wxCSConv conv(encoding);
|
||||||
size_t lenNeeded = conv.WC2MB(NULL, wchBuf, 0);
|
size_t lenNeeded = conv.WC2MB(NULL, wchBuf, 0);
|
||||||
if ( lenNeeded++ )
|
|
||||||
|
if ( lenNeeded != wxCONV_FAILED && lenNeeded++ )
|
||||||
{
|
{
|
||||||
conv.WC2MB(wxStringBuffer(out, lenNeeded), wchBuf, lenNeeded);
|
conv.WC2MB(wxStringBuffer(out, lenNeeded), wchBuf, lenNeeded);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user