projects
/
wxWidgets.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fixing some warnings
[wxWidgets.git]
/
src
/
common
/
imaggif.cpp
diff --git
a/src/common/imaggif.cpp
b/src/common/imaggif.cpp
index 74e573df34173d361ac0f14d8891f24e64064aa2..22a8dc04cca7c1ec2b2172f9a26a0c874510faaf 100644
(file)
--- a/
src/common/imaggif.cpp
+++ b/
src/common/imaggif.cpp
@@
-1,5
+1,5
@@
/////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
-// Name: imaggif.cpp
+// Name:
src/common/
imaggif.cpp
// Purpose: wxGIFHandler
// Author: Vaclav Slavik & Guillermo Rodriguez Garcia
// RCS-ID: $Id$
// Purpose: wxGIFHandler
// Author: Vaclav Slavik & Guillermo Rodriguez Garcia
// RCS-ID: $Id$
@@
-7,28
+7,23
@@
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
-#pragma implementation "imaggif.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
-
#
pragma hdrstop
+
#
pragma hdrstop
#endif
#endif
+#if wxUSE_IMAGE && wxUSE_GIF
+
#ifndef WX_PRECOMP
#ifndef WX_PRECOMP
-# include "wx/defs.h"
+ #include "wx/intl.h"
+ #include "wx/log.h"
#endif
#endif
-#if wxUSE_GIF
-
#include "wx/imaggif.h"
#include "wx/gifdecod.h"
#include "wx/wfstream.h"
#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)
IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler)
@@
-38,14
+33,16
@@
IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler)
#if wxUSE_STREAMS
#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;
{
wxGIFDecoder *decod;
-
int
error;
- bool ok;
+
wxGIFErrorCode
error;
+ bool ok
= true
;
- decod = new wxGIFDecoder(&stream, TRUE);
- error = decod->ReadGIF();
+// image->Destroy();
+ decod = new wxGIFDecoder();
+ error = decod->LoadGIF(stream);
if ((error != wxGIF_OK) && (error != wxGIF_TRUNCATED))
{
if ((error != wxGIF_OK) && (error != wxGIF_TRUNCATED))
{
@@
-54,30
+51,37
@@
bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose
switch (error)
{
case wxGIF_INVFORMAT:
switch (error)
{
case wxGIF_INVFORMAT:
- wxLogError(_("
wxGIFHandler
: error in GIF image format."));
+ wxLogError(_("
GIF
: error in GIF image format."));
break;
case wxGIF_MEMERR:
break;
case wxGIF_MEMERR:
- wxLogError(_("
wxGIFHandler
: not enough memory."));
+ wxLogError(_("
GIF
: not enough memory."));
break;
default:
break;
default:
- wxLogError(_("
wxGIFHandler
: unknown error!!!"));
+ wxLogError(_("
GIF
: unknown error!!!"));
break;
}
}
delete decod;
break;
}
}
delete decod;
- return
FALSE
;
+ return
false
;
}
if ((error == wxGIF_TRUNCATED) && verbose)
{
}
if ((error == wxGIF_TRUNCATED) && verbose)
{
- wxLog
Warning(_("wxGIFHandler
: data stream seems to be truncated."));
+ wxLog
Error(_("GIF
: data stream seems to be truncated."));
/* go on; image data is OK */
}
/* 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;
delete decod;
+
return ok;
}
return ok;
}
@@
-85,21
+89,15
@@
bool wxGIFHandler::SaveFile( wxImage * WXUNUSED(image),
wxOutputStream& WXUNUSED(stream), bool verbose )
{
if (verbose)
wxOutputStream& WXUNUSED(stream), bool verbose )
{
if (verbose)
- wxLogDebug(wxT("
wxGIFH
andler is read-only!!"));
+ wxLogDebug(wxT("
GIF: the h
andler is read-only!!"));
- return
FALSE
;
+ return
false
;
}
bool wxGIFHandler::DoCanRead( wxInputStream& stream )
{
}
bool wxGIFHandler::DoCanRead( wxInputStream& stream )
{
- wxGIFDecoder *decod;
- bool ok;
-
- decod = new wxGIFDecoder(&stream);
- ok = decod->CanRead();
-
- delete decod;
- return ok;
+ wxGIFDecoder decod;
+ return decod.CanRead(stream);
}
#endif // wxUSE_STREAMS
}
#endif // wxUSE_STREAMS