[SCM] libav/experimental: 100l: sometime palette was not copied to output frame

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 15:38:15 UTC 2013


The following commit has been merged in the experimental branch:
commit 1d768c3c169075cb33faab4cdff43df6a39acb68
Author: Roberto Togni <r_togni at tiscali.it>
Date:   Wed Nov 5 23:27:23 2003 +0000

    100l: sometime palette was not copied to output frame
    
    Originally committed as revision 2481 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavcodec/msrle.c b/libavcodec/msrle.c
index dffd55b..ce5c4c0 100644
--- a/libavcodec/msrle.c
+++ b/libavcodec/msrle.c
@@ -67,6 +67,13 @@ static void msrle_decode_pal8(MsrleContext *s)
     int row_ptr = (s->avctx->height - 1) * row_dec;
     int frame_size = row_dec * s->avctx->height;
 
+    /* make the palette available */
+    memcpy(s->frame.data[1], s->avctx->palctrl->palette, AVPALETTE_SIZE);
+    if (s->avctx->palctrl->palette_changed) {
+        s->frame.palette_has_changed = 1;
+        s->avctx->palctrl->palette_changed = 0;
+    }
+
     while (row_ptr >= 0) {
         FETCH_NEXT_STREAM_BYTE();
         rle_code = stream_byte;
@@ -128,13 +135,6 @@ static void msrle_decode_pal8(MsrleContext *s)
         }
     }
 
-    /* make the palette available */
-    memcpy(s->frame.data[1], s->avctx->palctrl->palette, AVPALETTE_SIZE);
-    if (s->avctx->palctrl->palette_changed) {
-        s->frame.palette_has_changed = 1;
-        s->avctx->palctrl->palette_changed = 0;
-    }
-
     /* one last sanity check on the way out */
     if (stream_ptr < s->size)
         av_log(s->avctx, AV_LOG_ERROR, " MS RLE: ended frame decode with bytes left over (%d < %d)\n",

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list