don't allocate 0-sized buffer in cWC2MB() even if input size is 0
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@39075 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -422,9 +422,15 @@ wxMBConv::cMB2WC(const char *inBuff, size_t inLen, size_t *outLen) const
|
|||||||
const wxCharBuffer
|
const wxCharBuffer
|
||||||
wxMBConv::cWC2MB(const wchar_t *inBuff, size_t inLen, size_t *outLen) const
|
wxMBConv::cWC2MB(const wchar_t *inBuff, size_t inLen, size_t *outLen) const
|
||||||
{
|
{
|
||||||
const size_t dstLen = FromWChar(NULL, 0, inBuff, inLen);
|
size_t dstLen = FromWChar(NULL, 0, inBuff, inLen);
|
||||||
if ( dstLen != wxCONV_FAILED )
|
if ( dstLen != wxCONV_FAILED )
|
||||||
{
|
{
|
||||||
|
if ( !dstLen )
|
||||||
|
{
|
||||||
|
// special case: can't allocate 0 size buffer below
|
||||||
|
dstLen++;
|
||||||
|
}
|
||||||
|
|
||||||
wxCharBuffer buf(dstLen - 1);
|
wxCharBuffer buf(dstLen - 1);
|
||||||
if ( FromWChar(buf.data(), dstLen, inBuff, inLen) != wxCONV_FAILED )
|
if ( FromWChar(buf.data(), dstLen, inBuff, inLen) != wxCONV_FAILED )
|
||||||
{
|
{
|
||||||
@@ -433,11 +439,12 @@ wxMBConv::cWC2MB(const wchar_t *inBuff, size_t inLen, size_t *outLen) const
|
|||||||
*outLen = dstLen;
|
*outLen = dstLen;
|
||||||
|
|
||||||
const size_t nulLen = GetMBNulLen();
|
const size_t nulLen = GetMBNulLen();
|
||||||
if ( !NotAllNULs(buf.data() + dstLen - nulLen, nulLen) )
|
if ( dstLen >= nulLen &&
|
||||||
|
!NotAllNULs(buf.data() + dstLen - nulLen, nulLen) )
|
||||||
{
|
{
|
||||||
// in this case the output is NUL-terminated and we're not
|
// in this case the output is NUL-terminated and we're not
|
||||||
// supposed to count NUL
|
// supposed to count NUL
|
||||||
(*outLen) -= nulLen;
|
*outLen -= nulLen;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user