X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8a68d8b6c13323ad187062b0be009f6d22af77f0..dcfb179bc7626b810b5dc589bd5db0e2bae0e8fb:/src/common/imaggif.cpp?ds=sidebyside diff --git a/src/common/imaggif.cpp b/src/common/imaggif.cpp index f719a2ad41..b8a5229e23 100644 --- a/src/common/imaggif.cpp +++ b/src/common/imaggif.cpp @@ -3,16 +3,16 @@ // Purpose: wxGIFHandler // Author: Vaclav Slavik & Guillermo Rodriguez Garcia // RCS-ID: $Id$ +// Copyright: (c) 1999 Vaclav Slavik & Guillermo Rodriguez Garcia // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -/* - We don't put pragma implement in this file because it is already present in - src/common/image.cpp -*/ +#ifdef __GNUG__ +#pragma implementation "imaggif.h" +#endif // For compilers that support precompilation, includes "wx.h". -#include +#include "wx/wxprec.h" #ifdef __BORLANDC__ # pragma hdrstop @@ -22,44 +22,62 @@ # include "wx/defs.h" #endif -#if 1 // change this to #if wxUSE_GIF +#if wxUSE_IMAGE && wxUSE_GIF -#include "wx/image.h" +#include "wx/imaggif.h" #include "wx/gifdecod.h" #include "wx/wfstream.h" -#include "wx/module.h" #include "wx/log.h" +#include "wx/intl.h" -#if !USE_SHARED_LIBRARIES IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler) -#endif - -#if wxUSE_STREAMS //----------------------------------------------------------------------------- // wxGIFHandler //----------------------------------------------------------------------------- -bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose ) +#if wxUSE_STREAMS + +bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose, int WXUNUSED(index) ) { wxGIFDecoder *decod; + int error; bool ok; +// image->Destroy(); decod = new wxGIFDecoder(&stream, TRUE); - - if (decod->ReadGIF() != E_OK) + error = decod->ReadGIF(); + + if ((error != wxGIF_OK) && (error != wxGIF_TRUNCATED)) { if (verbose) - wxLogDebug(_T("Error reading GIF")); - + { + switch (error) + { + case wxGIF_INVFORMAT: + wxLogError(_("GIF: error in GIF image format.")); + break; + case wxGIF_MEMERR: + wxLogError(_("GIF: not enough memory.")); + break; + default: + wxLogError(_("GIF: unknown error!!!")); + break; + } + } delete decod; return FALSE; } - image->Destroy(); - ok = decod->ConvertToImage(image); + if ((error == wxGIF_TRUNCATED) && verbose) + { + wxLogError(_("GIF: data stream seems to be truncated.")); + /* go on; image data is OK */ + } + ok = decod->ConvertToImage(image); delete decod; + return ok; } @@ -67,25 +85,23 @@ bool wxGIFHandler::SaveFile( wxImage * WXUNUSED(image), wxOutputStream& WXUNUSED(stream), bool verbose ) { if (verbose) - wxLogDebug(_T("wxGIFHandler is read-only!!")); + wxLogDebug(wxT("GIF: the handler is read-only!!")); return FALSE; } -bool wxGIFHandler::CanRead( wxInputStream& stream ) +bool wxGIFHandler::DoCanRead( wxInputStream& stream ) { wxGIFDecoder *decod; bool ok; decod = new wxGIFDecoder(&stream); ok = decod->CanRead(); - delete decod; + return ok; } -#endif - // wxUSE_STREAMS +#endif // wxUSE_STREAMS -#endif - // wxUSE_GIF +#endif // wxUSE_GIF