# HG changeset patch # User reimar # Date 1201991471 0 # Node ID 80f5ff30ba58322ae5d20bc512a4241de63e6def # Parent 9ac5c0cfeb5634864c0005764a3edafb87a5c0a7 Use bytestream_get_be24 to simplify palette parsing. diff -r 9ac5c0cfeb56 -r 80f5ff30ba58 smacker.c --- a/smacker.c Sat Feb 02 22:09:07 2008 +0000 +++ b/smacker.c Sat Feb 02 22:31:11 2008 +0000 @@ -35,6 +35,7 @@ #define ALT_BITSTREAM_READER_LE #include "bitstream.h" +#include "bytestream.h" #define SMKTREE_BITS 9 #define SMK_NODE 0x80000000 @@ -367,7 +368,6 @@ } /* make the palette available on the way out */ - out = buf + 1; pal = (uint32_t*)smk->pic.data[1]; smk->pic.palette_has_changed = buf[0] & 1; smk->pic.key_frame = !!(buf[0] & 2); @@ -376,19 +376,16 @@ else smk->pic.pict_type = FF_P_TYPE; - for(i = 0; i < 256; i++) { - int r, g, b; - r = *out++; - g = *out++; - b = *out++; - *pal++ = (r << 16) | (g << 8) | b; - } + buf++; + for(i = 0; i < 256; i++) + *pal++ = bytestream_get_be24(&buf); + buf_size -= 769; last_reset(smk->mmap_tbl, smk->mmap_last); last_reset(smk->mclr_tbl, smk->mclr_last); last_reset(smk->full_tbl, smk->full_last); last_reset(smk->type_tbl, smk->type_last); - init_get_bits(&gb, buf + 769, (buf_size - 769) * 8); + init_get_bits(&gb, buf, buf_size * 8); blk = 0; bw = avctx->width >> 2;