From: Julian Smart Date: Wed, 30 Jan 2008 17:03:10 +0000 (+0000) Subject: Added checks to encoding conversion to avoid crash X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/b212c69ecaaa3b855d9d2195d2432fb9684e35d6 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 --- diff --git a/src/msw/textctrl.cpp b/src/msw/textctrl.cpp index 9293dcebb7..52e5add304 100644 --- a/src/msw/textctrl.cpp +++ b/src/msw/textctrl.cpp @@ -974,6 +974,9 @@ wxTextCtrl::StreamIn(const wxString& value, const size_t len = conv.MB2WC(NULL, value.mb_str(), value.length()); + if (len == wxCONV_FAILED) + return false; + #if wxUSE_WCHAR_T wxWCharBuffer wchBuf(len); wchar_t *wpc = wchBuf.data(); @@ -1066,7 +1069,8 @@ wxTextCtrl::StreamOut(wxFontEncoding encoding, bool selectionOnly) const // conversion but what else can we do) wxCSConv conv(encoding); size_t lenNeeded = conv.WC2MB(NULL, wchBuf, 0); - if ( lenNeeded++ ) + + if ( lenNeeded != wxCONV_FAILED && lenNeeded++ ) { conv.WC2MB(wxStringBuffer(out, lenNeeded), wchBuf, lenNeeded); }