Go back to my original idea of checking for EILSEQ and EINVAL and failing
immediately if either of those is set after wxVsnprintf call returns a negative number to indicate some type of failure. All other errno are assumed to simply mean that the buffer is undersized so the platform C library function can set errno to anything it likes or simply not set it at all and our code will keep trying to increase the buffer size just as it did originally. This should (hopefully) fix compilation with C libraries that only support the most basic set of errors (of which EINVAL and EILSEQ are part). git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@49342 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
4488a1d332
commit
a9a854d73e
@ -1603,12 +1603,24 @@ int wxString::DoPrintfUtf8(const char *format, ...)
|
|||||||
and set errno.
|
and set errno.
|
||||||
|
|
||||||
What vswprintf sets errno to is undefined but Darwin seems to set it to
|
What vswprintf sets errno to is undefined but Darwin seems to set it to
|
||||||
EOVERFLOW. The only expected errno that are defined anywhere are by an
|
EOVERFLOW. The only expected errno are EILSEQ and EINVAL. Both of
|
||||||
addendum indicating that EILSEQ should be set for bad input characters and
|
those are defined in the standard and backed up by several conformance
|
||||||
EINVALID for bad arguments such as a NULL buffer pointer. It would appear
|
statements. Note that ENOMEM mentioned in the manual page does not
|
||||||
that setting EOVERFLOW is not documented anywhere and has only been at
|
apply to swprintf, only wprintf and fwprintf.
|
||||||
this time observed on Darwin.
|
|
||||||
|
|
||||||
|
Official manual page:
|
||||||
|
http://www.opengroup.org/onlinepubs/009695399/functions/swprintf.html
|
||||||
|
|
||||||
|
Some conformance statements (AIX, Solaris):
|
||||||
|
http://www.opengroup.org/csq/view.mhtml?RID=ibm%2FSD1%2F3
|
||||||
|
http://www.theopengroup.org/csq/view.mhtml?norationale=1&noreferences=1&RID=Fujitsu%2FSE2%2F10
|
||||||
|
|
||||||
|
Since EILSEQ and EINVAL are rather common but EOVERFLOW is not and since
|
||||||
|
EILSEQ and EINVAL are specifically defined to mean the error is other than
|
||||||
|
an undersized buffer and no other errno are defined we treat those two
|
||||||
|
as meaning hard errors and everything else gets the old behavior which
|
||||||
|
is to keep looping and increasing buffer size until the function succeeds.
|
||||||
|
|
||||||
In practice it's impossible to determine before compilation which behavior
|
In practice it's impossible to determine before compilation which behavior
|
||||||
may be used. The vswprintf function may have vsnprintf-like behavior or
|
may be used. The vswprintf function may have vsnprintf-like behavior or
|
||||||
vice-versa. Behavior detected on one release can theoretically change
|
vice-versa. Behavior detected on one release can theoretically change
|
||||||
@ -1704,16 +1716,15 @@ static int DoStringPrintfV(wxString& str,
|
|||||||
// as we don't know how much we need, double the current size of
|
// as we don't know how much we need, double the current size of
|
||||||
// the buffer
|
// the buffer
|
||||||
#ifndef __WXWINCE__
|
#ifndef __WXWINCE__
|
||||||
if( (errno == 0) || (errno == EOVERFLOW) )
|
if( (errno == EILSEQ) || (errno == EINVAL) )
|
||||||
|
// If errno was set to one of the two well-known hard errors
|
||||||
|
// then fail immediately to avoid an infinite loop.
|
||||||
|
return -1;
|
||||||
|
else
|
||||||
|
#endif // __WXWINCE__
|
||||||
// still not enough, as we don't know how much we need, double the
|
// still not enough, as we don't know how much we need, double the
|
||||||
// current size of the buffer
|
// current size of the buffer
|
||||||
size *= 2;
|
size *= 2;
|
||||||
else
|
|
||||||
// If errno was set to something else, assume hard failure.
|
|
||||||
return -1;
|
|
||||||
#else
|
|
||||||
size *= 2;
|
|
||||||
#endif // __WXWINCE__
|
|
||||||
#endif // wxUSE_WXVSNPRINTF/!wxUSE_WXVSNPRINTF
|
#endif // wxUSE_WXVSNPRINTF/!wxUSE_WXVSNPRINTF
|
||||||
}
|
}
|
||||||
else if ( len >= size )
|
else if ( len >= size )
|
||||||
|
Loading…
Reference in New Issue
Block a user