# HG changeset patch # User kostya # Date 1228553851 0 # Node ID 48dcf657f897592787b7c1e16ab820eed08cabd2 # Parent 2e8368ea591aaadb51c707b43f22a954fe163ef3 AASC can contain raw data in addition to MS-RLE diff -r 2e8368ea591a -r 48dcf657f897 aasc.c --- a/aasc.c Fri Dec 05 21:44:18 2008 +0000 +++ b/aasc.c Sat Dec 06 08:57:31 2008 +0000 @@ -62,6 +62,7 @@ const uint8_t *buf, int buf_size) { AascContext *s = avctx->priv_data; + int compr, i, stride; s->frame.reference = 1; s->frame.buffer_hints = FF_BUFFER_HINTS_VALID | FF_BUFFER_HINTS_PRESERVE | FF_BUFFER_HINTS_REUSABLE; @@ -70,7 +71,24 @@ return -1; } - ff_msrle_decode(avctx, &s->frame, 8, buf, buf_size); + compr = AV_RL32(buf); + buf += 4; + buf_size -= 4; + switch(compr){ + case 0: + stride = (avctx->width * 3 + 3) & ~3; + for(i = avctx->height - 1; i >= 0; i--){ + memcpy(s->frame.data[0] + i*s->frame.linesize[0], buf, avctx->width*3); + buf += stride; + } + break; + case 1: + ff_msrle_decode(avctx, &s->frame, 8, buf - 4, buf_size + 4); + break; + default: + av_log(avctx, AV_LOG_ERROR, "Unknown compression type %d\n", compr); + return -1; + } *data_size = sizeof(AVFrame); *(AVFrame*)data = s->frame;