NAME
Image::Leptonica::Func::gifio
VERSION
version 0.03
gifio.c
gifio.c
Read gif from file
PIX *pixReadStreamGif()
static PIX *pixInterlaceGIF()
Write gif to file
l_int32 pixWriteStreamGif()
Read/write from/to memory (see warning)
PIX *pixReadMemGif()
l_int32 pixWriteMemGif()
This uses the gif library, version 4.1.6 or later.
Do not use 4.1.4. It has serious problems handling 1 bpp images.
The initial version of this module was generously contribued by
Antony Dovgal. He can be contacted at: tony *AT* daylessday.org
There are some issues with version 5:
- valgrind detects uninitialized values used used for writing
and conditionally jumping in EGifPutScreenDesc().
- DGifSlurp() crashes on some images, apparently triggered by
by some GIF extension records. The latter problem has been
reported but not resolved as of October 2013.
FUNCTIONS
pixReadMemGif
PIX * pixReadMemGif ( const l_uint8 *cdata, size_t size )
pixReadMemGif()
Input: data (const; gif-encoded)
size (of data)
Return: pix, or null on error
Notes:
(1) Of course, we are cheating here -- writing the data to file
in gif format and reading it back in. We can't use the
GNU runtime extension fmemopen() to avoid writing to a file
because libgif doesn't have a file stream interface!
(2) This should not be assumed to be safe from a sophisticated
attack, even though we have attempted to make the filename
difficult to guess by embedding the process number and the
current time in microseconds. The best way to handle
temporary files is to use file descriptors (capabilities)
or file handles. However, I know of no way to do this
for gif files because of the way that libgif handles the
file descriptors. The canonical approach would be to do this:
char templ[] = "hiddenfilenameXXXXXX";
l_int32 fd = mkstemp(templ);
FILE *fp = fdopen(fd, "w+b");
fwrite(data, 1, size, fp);
rewind(fp);
Pix *pix = pixReadStreamGif(fp);
but this fails because fp is in a bad state after writing.
pixReadStreamGif
PIX * pixReadStreamGif ( FILE *fp )
pixReadStreamGif()
Input: stream
Return: pix, or null on error
pixWriteMemGif
l_int32 pixWriteMemGif ( l_uint8 **pdata, size_t *psize, PIX *pix )
pixWriteMemGif()
Input: &data (<return> data of gif compressed image)
&size (<return> size of returned data)
pix
Return: 0 if OK, 1 on error
Notes:
(1) See comments in pixReadMemGif()
pixWriteStreamGif
l_int32 pixWriteStreamGif ( FILE *fp, PIX *pix )
pixWriteStreamGif()
Input: stream
pix (1, 2, 4, 8, 16 or 32 bpp)
Return: 0 if OK, 1 on error
Notes:
(1) All output gif have colormaps. If the pix is 32 bpp rgb,
this quantizes the colors and writes out 8 bpp.
If the pix is 16 bpp grayscale, it converts to 8 bpp first.
(2) We can't write to memory using open_memstream() because
the gif functions write through a file descriptor, not a
file stream.
AUTHOR
Zakariyya Mughal <zmughal@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Zakariyya Mughal.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.