/////////////////////////////////////////////////////////////////////////////
-// Name: imaggif.cpp
+// Name: src/common/imaggif.cpp
// Purpose: wxGIFHandler
// Author: Vaclav Slavik & Guillermo Rodriguez Garcia
// RCS-ID: $Id$
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
-#pragma implementation "imaggif.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
-# pragma hdrstop
+ #pragma hdrstop
#endif
+#if wxUSE_IMAGE && wxUSE_GIF
+
#ifndef WX_PRECOMP
-# include "wx/defs.h"
+ #include "wx/intl.h"
+ #include "wx/log.h"
#endif
-#if wxUSE_GIF
-
#include "wx/imaggif.h"
#include "wx/gifdecod.h"
#include "wx/wfstream.h"
-#include "wx/log.h"
-#include "wx/intl.h"
IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler)
#if wxUSE_STREAMS
-bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose, int WXUNUSED(index) )
+bool wxGIFHandler::LoadFile(wxImage *image, wxInputStream& stream,
+ bool verbose, int index)
{
wxGIFDecoder *decod;
- int error;
- bool ok;
+ wxGIFErrorCode error;
+ bool ok = true;
- decod = new wxGIFDecoder(&stream, TRUE);
+// image->Destroy();
+ decod = new wxGIFDecoder();
+ error = decod->LoadGIF(stream);
- if ((error = decod->ReadGIF()) != wxGIF_OK)
+ if ((error != wxGIF_OK) && (error != wxGIF_TRUNCATED))
{
if (verbose)
{
switch (error)
{
- case wxGIF_INVFORMAT: wxLogError(_("wxGIFHandler: error in GIF image format")); break;
- case wxGIF_MEMERR: wxLogError(_("wxGIFHandler: couldn't allocate enough memory")); break;
- default: wxLogError(_("wxGIFHandler: unknown 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;
+ return false;
+ }
+
+ if ((error == wxGIF_TRUNCATED) && verbose)
+ {
+ wxLogError(_("GIF: data stream seems to be truncated."));
+ /* go on; image data is OK */
}
- image->Destroy();
- ok = decod->ConvertToImage(image);
+ if (ok)
+ {
+ ok = decod->ConvertToImage(index != -1 ? (size_t)index : 0, image);
+ }
+ else
+ {
+ wxLogError(_("GIF: Invalid gif index."));
+ }
delete decod;
+
return ok;
}
wxOutputStream& WXUNUSED(stream), bool verbose )
{
if (verbose)
- wxLogDebug(wxT("wxGIFHandler is read-only!!"));
+ {
+ wxLogDebug(wxT("GIF: the handler is read-only!!"));
+ }
- return FALSE;
+ return false;
}
bool wxGIFHandler::DoCanRead( wxInputStream& stream )
{
- wxGIFDecoder *decod;
- bool ok;
-
- decod = new wxGIFDecoder(&stream);
- ok = decod->CanRead();
+ wxGIFDecoder decod;
+ return decod.CanRead(stream);
+ // it's ok to modify the stream position here
+}
- delete decod;
- return ok;
+int wxGIFHandler::DoGetImageCount( wxInputStream& stream )
+{
+ wxGIFDecoder decod;
+ wxGIFErrorCode error = decod.LoadGIF(stream);
+ if ( (error != wxGIF_OK) && (error != wxGIF_TRUNCATED) )
+ return -1;
+
+ // NOTE: this function modifies the current stream position but it's ok
+ // (see wxImageHandler::GetImageCount)
+
+ return decod.GetFrameCount();
}
#endif // wxUSE_STREAMS