X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=deanimate.c;h=59ed56e96c25bf64b84c6ea24663248f8392e3f8;hp=637743b9d73291bb0b664e310ca51fecc5e08e67;hb=9a67299e616ef4b3e527f8837474f3a9819fad3c;hpb=f0964104e2d5c2cdf398524bee3f91e0feac0c30 diff --git a/deanimate.c b/deanimate.c index 637743b9..59ed56e9 100644 --- a/deanimate.c +++ b/deanimate.c @@ -1,4 +1,4 @@ -const char deanimate_rcs[] = "$Id: deanimate.c,v 1.3 2001/07/15 13:57:50 jongfoster Exp $"; +const char deanimate_rcs[] = "$Id: deanimate.c,v 1.11 2002/03/26 22:29:54 swa Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/deanimate.c,v $ @@ -10,7 +10,7 @@ const char deanimate_rcs[] = "$Id: deanimate.c,v 1.3 2001/07/15 13:57:50 jongfos * gif_extract_image * * Copyright : Written by and Copyright (C) 2001 by the the SourceForge - * IJBSWA team. http://ijbswa.sourceforge.net + * Privoxy team. http://www.privoxy.org/ * * Based on the GIF file format specification (see * http://tronche.com/computer-graphics/gif/gif89a.html) @@ -37,6 +37,34 @@ const char deanimate_rcs[] = "$Id: deanimate.c,v 1.3 2001/07/15 13:57:50 jongfos * * Revisions : * $Log: deanimate.c,v $ + * Revision 1.11 2002/03/26 22:29:54 swa + * we have a new homepage! + * + * Revision 1.10 2002/03/24 13:25:43 swa + * name change related issues + * + * Revision 1.9 2002/03/13 00:27:04 jongfoster + * Killing warnings + * + * Revision 1.8 2002/03/09 19:42:47 jongfoster + * Fixing more warnings + * + * Revision 1.7 2002/03/08 17:46:04 jongfoster + * Fixing int/size_t warnings + * + * Revision 1.6 2002/03/07 03:46:17 oes + * Fixed compiler warnings + * + * Revision 1.5 2001/09/10 10:16:06 oes + * Silenced compiler warnings + * + * Revision 1.4 2001/07/18 12:28:49 oes + * - Added feature for extracting the first frame + * to gif_deanimate + * - Separated image buffer extension into buf_extend + * - Extended gif deanimation to GIF87a (untested!) + * - Cosmetics + * * Revision 1.3 2001/07/15 13:57:50 jongfoster * Adding #includes string.h and miscutil.h * @@ -90,7 +118,7 @@ void buf_free(struct binbuffer *buf) * * Description : Ensure that a given binbuffer can hold a given amount * of bytes, by reallocating its buffer if necessary. - * Allocate new mem in chunks of 1000 bytes, so we don't + * Allocate new mem in chunks of 1024 bytes, so we don't * have to realloc() too often. * * Parameters : @@ -101,13 +129,13 @@ void buf_free(struct binbuffer *buf) * Returns : 0 on success, 1 on failiure. * *********************************************************************/ -int buf_extend(struct binbuffer *buf, int length) +int buf_extend(struct binbuffer *buf, size_t length) { char *newbuf; if (buf->offset + length > buf->size) { - buf->size = buf->size + length + 1000 - (buf->size + length) % 1000; + buf->size = ((buf->size + length + (size_t)1023) & ~(size_t)1023); newbuf = (char *)realloc(buf->buffer, buf->size); if (newbuf == NULL) @@ -142,7 +170,7 @@ int buf_extend(struct binbuffer *buf, int length) * Returns : 0 on success, 1 on failiure. * *********************************************************************/ -int buf_copy(struct binbuffer *src, struct binbuffer *dst, int length) +int buf_copy(struct binbuffer *src, struct binbuffer *dst, size_t length) { /* @@ -182,13 +210,13 @@ int buf_copy(struct binbuffer *src, struct binbuffer *dst, int length) * given offset * * Parameters : - * 1 : buf = Pointer to the source binbuffer + * 1 : src = Pointer to the source binbuffer * 2 : offset = Offset to the desired byte * * Returns : The byte on success, or 0 on failiure * *********************************************************************/ -unsigned char buf_getbyte(struct binbuffer *src, int offset) +unsigned char buf_getbyte(struct binbuffer *src, size_t offset) { if (src->offset + offset < src->size) { @@ -226,7 +254,7 @@ int gif_skip_data_block(struct binbuffer *buf) * by a one-byte length field, with the last chunk having * zero length. */ - while(c = buf_getbyte(buf, 0)) + while((c = buf_getbyte(buf, 0)) != '\0') { if ((buf->offset += c + 1) >= buf->size - 1) { @@ -274,7 +302,7 @@ int gif_extract_image(struct binbuffer *src, struct binbuffer *dst) */ if (c & 0x80) { - if (buf_copy(src, dst, 3 * (1 << ((c & 0x07) + 1)))) + if (buf_copy(src, dst, (size_t) 3 * (1 << ((c & 0x07) + 1)))) { return 1; } @@ -284,9 +312,9 @@ int gif_extract_image(struct binbuffer *src, struct binbuffer *dst) /* * Copy the image chunk by chunk. */ - while(c = buf_getbyte(src, 0)) + while((c = buf_getbyte(src, 0)) != '\0') { - if (buf_copy(src, dst, c + 1)) return 1; + if (buf_copy(src, dst, 1 + (size_t) c)) return 1; } if (buf_copy(src, dst, 1)) return 1; @@ -353,7 +381,7 @@ int gif_deanimate(struct binbuffer *src, struct binbuffer *dst, int get_first_im */ if(c & 0x80) { - if (buf_copy(src, dst, 3 * (1 << ((c & 0x07) + 1)))) + if (buf_copy(src, dst, (size_t) 3 * (1 << ((c & 0x07) + 1)))) { return 1; }