fixed error logging in TIFF image handler to output something useful regardless of the build
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@53614 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -32,6 +32,7 @@
|
|||||||
#include "wx/intl.h"
|
#include "wx/intl.h"
|
||||||
#include "wx/bitmap.h"
|
#include "wx/bitmap.h"
|
||||||
#include "wx/module.h"
|
#include "wx/module.h"
|
||||||
|
#include "wx/wxcrtvararg.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
@@ -61,39 +62,38 @@ extern "C"
|
|||||||
// TIFF library error/warning handlers
|
// TIFF library error/warning handlers
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static wxString
|
||||||
|
FormatTiffMessage(const char *module, const char *fmt, va_list ap)
|
||||||
|
{
|
||||||
|
char buf[512];
|
||||||
|
if ( wxCRT_VsnprintfA(buf, WXSIZEOF(buf), fmt, ap) <= 0 )
|
||||||
|
{
|
||||||
|
// this isn't supposed to happen, but if it does, it's better
|
||||||
|
// than nothing
|
||||||
|
strcpy(buf, "Incorrectly formatted TIFF message");
|
||||||
|
}
|
||||||
|
buf[WXSIZEOF(buf)-1] = 0; // make sure it is always NULL-terminated
|
||||||
|
|
||||||
|
wxString msg(buf);
|
||||||
|
if ( module )
|
||||||
|
msg += wxString::Format(_(" (in module \"%s\")"), module);
|
||||||
|
|
||||||
|
return msg;
|
||||||
|
}
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
|
|
||||||
static void
|
static void
|
||||||
TIFFwxWarningHandler(const char* module,
|
TIFFwxWarningHandler(const char* module, const char *fmt, va_list ap)
|
||||||
const char* WXUNUSED_IN_UNICODE(fmt),
|
|
||||||
va_list WXUNUSED_IN_UNICODE(ap))
|
|
||||||
{
|
{
|
||||||
if (module != NULL)
|
wxLogWarning("%s", FormatTiffMessage(module, fmt, ap));
|
||||||
wxLogWarning(_("tiff module: %s"), wxString::FromAscii(module).c_str());
|
|
||||||
|
|
||||||
// FIXME: this is not terrible informative but better than crashing!
|
|
||||||
#if wxUSE_UNICODE
|
|
||||||
wxLogWarning(_("TIFF library warning."));
|
|
||||||
#else
|
|
||||||
wxVLogWarning(fmt, ap);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
TIFFwxErrorHandler(const char* module,
|
TIFFwxErrorHandler(const char* module, const char *fmt, va_list ap)
|
||||||
const char* WXUNUSED_IN_UNICODE(fmt),
|
|
||||||
va_list WXUNUSED_IN_UNICODE(ap))
|
|
||||||
{
|
{
|
||||||
if (module != NULL)
|
wxLogError("%s", FormatTiffMessage(module, fmt, ap));
|
||||||
wxLogError(_("tiff module: %s"), wxString::FromAscii(module).c_str());
|
|
||||||
|
|
||||||
// FIXME: as above
|
|
||||||
#if wxUSE_UNICODE
|
|
||||||
wxLogError(_("TIFF library error."));
|
|
||||||
#else
|
|
||||||
wxVLogError(fmt, ap);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
Reference in New Issue
Block a user