ansi: do not depend on get_buffer() initializing the frame.
authorAnton Khirnov <anton@khirnov.net>
Thu, 15 Nov 2012 13:24:51 +0000 (14:24 +0100)
committerAnton Khirnov <anton@khirnov.net>
Mon, 24 Dec 2012 08:17:45 +0000 (09:17 +0100)
The background changes from 128 (used by the default/cmdutils
get_buffer()) to 0. This looks more correct.

libavcodec/ansi.c
tests/ref/fate/ansi

index c2a1d83..861d4e5 100644 (file)
@@ -325,6 +325,11 @@ static int decode_frame(AVCodecContext *avctx,
         av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
         return ret;
     }
+    if (!avctx->frame_number) {
+        memset(s->frame.data[0], 0, avctx->height * FFABS(s->frame.linesize[0]));
+        memset(s->frame.data[1], 0, AVPALETTE_SIZE);
+    }
+
     s->frame.pict_type           = AV_PICTURE_TYPE_I;
     s->frame.palette_has_changed = 1;
     memcpy(s->frame.data[1], ff_cga_palette, 16 * 4);
index 56c0226..78e853f 100644 (file)
@@ -1,7 +1,7 @@
 #tb 0: 1/25
-0,          0,          0,        1,   768000, 0x3032d0de
-0,          1,          1,        1,   768000, 0xc3be5922
-0,          2,          2,        1,   768000, 0xf530c476
+0,          0,          0,        1,   768000, 0x772dd3d0
+0,          1,          1,        1,   768000, 0xd7dab1d1
+0,          2,          2,        1,   768000, 0x0e56f2d3
 0,          3,          3,        1,   768000, 0x11c1fb8e
 0,          4,          4,        1,   768000, 0x72d12da9
 0,          5,          5,        1,   768000, 0x39c7a70d