X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0828c0875e1516e4bfc0aa5b0a84195a2ac92cca..dd60b9ec1e436bfa13eb94ffb69f921aef534eb0:/src/common/imaggif.cpp?ds=sidebyside diff --git a/src/common/imaggif.cpp b/src/common/imaggif.cpp index c6a775e15c..94f404a507 100644 --- a/src/common/imaggif.cpp +++ b/src/common/imaggif.cpp @@ -1,15 +1,15 @@ ///////////////////////////////////////////////////////////////////////////// // Name: imaggif.cpp // Purpose: wxGIFHandler -// Author: Vaclav Slavik -// Based on wxGIFDecoder by Guillermo Rodriguez Garcia +// 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 + We don't put pragma implement in this file because it is already present in + src/common/image.cpp */ // For compilers that support precompilation, includes "wx.h". @@ -23,31 +23,42 @@ src/common/image.cpp # include "wx/defs.h" #endif +#if 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" +#if !USE_SHARED_LIBRARIES IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler) - -#if wxUSE_STREAMS +#endif //----------------------------------------------------------------------------- // wxGIFHandler //----------------------------------------------------------------------------- -bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool WXUNUSED(verbose) ) +#if wxUSE_STREAMS + +bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose ) { wxGIFDecoder *decod; + int error; bool ok; decod = new wxGIFDecoder(&stream, TRUE); - - if (decod->ReadGIF() != E_OK) + + if ((error = decod->ReadGIF()) != E_OK) { - wxLogDebug(_T("Error reading GIF")); + if (verbose) + { + switch (error) + { + case E_FORMATO: wxLogError(wxT("wxGIFHandler: error in image format")); break; + case E_MEMORIA: wxLogError(wxT("wxGIFHandler: couldn't allocate memory")); break; + default: wxLogError(wxT("wxGIFHandler: unknown error !!!")); + } + } delete decod; return FALSE; } @@ -62,17 +73,24 @@ bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool WXUNUSE bool wxGIFHandler::SaveFile( wxImage * WXUNUSED(image), wxOutputStream& WXUNUSED(stream), bool verbose ) { - if (verbose) wxLogDebug(_T("wxGIFHandler is read-only!!")); + if (verbose) + wxLogDebug(wxT("wxGIFHandler is read-only!!")); + return FALSE; } -bool wxGIFHandler::CanRead( wxInputStream& stream ) +bool wxGIFHandler::DoCanRead( wxInputStream& stream ) { - unsigned char hdr[5]; - - stream.Read(&hdr, 5); - stream.SeekI(-5, wxFromCurrent); - return (hdr[0] == 'G' && hdr[1] == 'I' && hdr[2] == 'F' && hdr[3] == '8' && hdr[4] == '9'); + wxGIFDecoder *decod; + bool ok; + + decod = new wxGIFDecoder(&stream); + ok = decod->CanRead(); + + delete decod; + return ok; } -#endif +#endif // wxUSE_STREAMS + +#endif // wxUSE_GIF