diff options
author | Kostya Shishkov <kostya.shishkov@gmail.com> | 2006-11-13 11:34:46 +0000 |
---|---|---|
committer | Kostya Shishkov <kostya.shishkov@gmail.com> | 2006-11-13 11:34:46 +0000 |
commit | 339aabd5a8febca54117ffc11866d4240ba8d215 (patch) | |
tree | d50eb8cb4594be01b9cbfd0c22bf6468786a6bfe | |
parent | 9cc6be9d27373eaaf04233d06fc01a244627f5d4 (diff) | |
download | ffmpeg-339aabd5a8febca54117ffc11866d4240ba8d215.tar.gz |
Use table for determining type sizes
Originally committed as revision 7009 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavcodec/tiff.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/libavcodec/tiff.c b/libavcodec/tiff.c index ec7839cc82..d0177fa62b 100644 --- a/libavcodec/tiff.c +++ b/libavcodec/tiff.c @@ -62,6 +62,11 @@ enum TiffTypes{ TIFF_LONGLONG }; +/** sizes of various TIFF field types */ +static const int type_sizes[6] = { + 0, 1, 100, 2, 4, 8 +}; + typedef struct TiffContext { AVCodecContext *avctx; AVFrame picture; @@ -208,6 +213,8 @@ static int tiff_decode_tag(TiffContext *s, uint8_t *start, uint8_t *buf, uint8_t value = -1; buf = start + off; } + }else if(type_sizes[type] * count <= 4){ + buf -= 4; }else{ buf = start + off; } @@ -397,11 +404,11 @@ static int tiff_decode_tag(TiffContext *s, uint8_t *start, uint8_t *buf, uint8_t return -1; } pal = s->picture.data[1]; - off = (type == TIFF_SHORT) ? 2 : 1; + off = type_sizes[type]; rp = buf; gp = buf + count / 3 * off; bp = buf + count / 3 * off * 2; - off = (type == TIFF_SHORT) ? 8 : 0; + off = (type_sizes[type] - 1) << 3; for(i = 0; i < count / 3; i++){ j = (tget(&rp, type, s->le) >> off) << 16; j |= (tget(&gp, type, s->le) >> off) << 8; |