X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=deanimate.c;h=1dbc66513b85a147ba7e75121b09335e78d58230;hp=f7aead82c1e8c7172be887b60488b9d285b0e68f;hb=3ccc326dd535fc4f3a08c2ba87851fcb17f969ef;hpb=da23dc8543fc54465eb3d247c7b67188cce2abcd diff --git a/deanimate.c b/deanimate.c index f7aead82..1dbc6651 100644 --- a/deanimate.c +++ b/deanimate.c @@ -1,4 +1,4 @@ -const char deanimate_rcs[] = "$Id: deanimate.c,v 1.4 2001/07/18 12:28:49 oes Exp $"; +const char deanimate_rcs[] = "$Id: deanimate.c,v 1.7 2002/03/08 17:46:04 jongfoster Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/deanimate.c,v $ @@ -37,6 +37,15 @@ const char deanimate_rcs[] = "$Id: deanimate.c,v 1.4 2001/07/18 12:28:49 oes Exp * * Revisions : * $Log: deanimate.c,v $ + * 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 @@ -97,7 +106,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 : @@ -108,13 +117,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) @@ -149,7 +158,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) { /* @@ -195,7 +204,7 @@ int buf_copy(struct binbuffer *src, struct binbuffer *dst, int length) * 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) { @@ -281,7 +290,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; } @@ -293,7 +302,7 @@ int gif_extract_image(struct binbuffer *src, struct binbuffer *dst) */ while((c = buf_getbyte(src, 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; @@ -360,7 +369,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; }