#include "wx/intl.h"
#include "wx/module.h"
+#ifndef TIFFLINKAGEMODE
+ #define TIFFLINKAGEMODE LINKAGEMODE
+#endif
+
//-----------------------------------------------------------------------------
// wxTIFFHandler
//-----------------------------------------------------------------------------
IMPLEMENT_DYNAMIC_CLASS(wxTIFFHandler,wxImageHandler)
-static tsize_t LINKAGEMODE
+extern "C"
+{
+
+tsize_t TIFFLINKAGEMODE
_tiffNullProc(thandle_t WXUNUSED(handle),
- tdata_t WXUNUSED(buf),
- tsize_t WXUNUSED(size))
+ tdata_t WXUNUSED(buf),
+ tsize_t WXUNUSED(size))
{
return (tsize_t) -1;
}
-static tsize_t LINKAGEMODE
+tsize_t TIFFLINKAGEMODE
_tiffReadProc(thandle_t handle, tdata_t buf, tsize_t size)
{
wxInputStream *stream = (wxInputStream*) handle;
return stream->LastRead();
}
-static tsize_t LINKAGEMODE
+tsize_t TIFFLINKAGEMODE
_tiffWriteProc(thandle_t handle, tdata_t buf, tsize_t size)
{
wxOutputStream *stream = (wxOutputStream*) handle;
return stream->LastWrite();
}
-static toff_t LINKAGEMODE
+toff_t TIFFLINKAGEMODE
_tiffSeekIProc(thandle_t handle, toff_t off, int whence)
{
wxInputStream *stream = (wxInputStream*) handle;
return (toff_t)stream->SeekI( (off_t)off, mode );
}
-static toff_t LINKAGEMODE
+toff_t TIFFLINKAGEMODE
_tiffSeekOProc(thandle_t handle, toff_t off, int whence)
{
wxOutputStream *stream = (wxOutputStream*) handle;
return (toff_t)stream->SeekO( (off_t)off, mode );
}
-static int LINKAGEMODE
+int TIFFLINKAGEMODE
_tiffCloseProc(thandle_t WXUNUSED(handle))
{
return 0; // ?
}
-static toff_t LINKAGEMODE
+toff_t TIFFLINKAGEMODE
_tiffSizeProc(thandle_t handle)
{
wxStreamBase *stream = (wxStreamBase*) handle;
return (toff_t) stream->GetSize();
}
-static int LINKAGEMODE
+int TIFFLINKAGEMODE
_tiffMapProc(thandle_t WXUNUSED(handle),
tdata_t* WXUNUSED(pbase),
toff_t* WXUNUSED(psize))
return 0;
}
-static void LINKAGEMODE
+void TIFFLINKAGEMODE
_tiffUnmapProc(thandle_t WXUNUSED(handle),
tdata_t WXUNUSED(base),
toff_t WXUNUSED(size))
{
}
+} // extern "C"
+
TIFF*
TIFFwxOpen(wxInputStream &stream, const char* name, const char* mode)
{
bool wxTIFFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose, int index )
{
+ if (index == -1)
+ index = 0;
+
image->Destroy();
TIFF *tif = TIFFwxOpen( stream, "image", "r" );
unsigned char *ptr = image->GetData();
for (int row = 0; row < image->GetHeight(); row++)
{
- if (buf)
- memcpy(buf, ptr, image->GetWidth());
+ if (buf)
+ memcpy(buf, ptr, image->GetWidth());
- if (TIFFWriteScanline(tif, buf ? buf : ptr, (uint32)row, 0) < 0)
+ if (TIFFWriteScanline(tif, buf ? buf : ptr, (uint32)row, 0) < 0)
{
- if (verbose)
- wxLogError( _("TIFF: Error writing image.") );
+ if (verbose)
+ wxLogError( _("TIFF: Error writing image.") );
TIFFClose( tif );
if (buf)