[SCM] libav/experimental: get rid of xsubdec array and calculate value instead

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 16:04:51 UTC 2013


The following commit has been merged in the experimental branch:
commit d6136c761822ab1fbcb8881080a6b98227b2cb14
Author: Reimar Döffinger <Reimar.Doeffinger at gmx.de>
Date:   Sun Aug 5 12:11:20 2007 +0000

    get rid of xsubdec array and calculate value instead
    
    Originally committed as revision 9938 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavcodec/xsubdec.c b/libavcodec/xsubdec.c
index 2a858f6..f2ef39b 100644
--- a/libavcodec/xsubdec.c
+++ b/libavcodec/xsubdec.c
@@ -24,8 +24,6 @@ static uint64_t parse_timecode(AVCodecContext *avctx, uint8_t *buf) {
     return ms;
 }
 
-static const uint8_t runbits[8] = { 14, 14, 10, 10, 6, 6, 2, 2 };
-
 static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
                         uint8_t *buf, int buf_size) {
     AVSubtitle *sub = data;
@@ -85,7 +83,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
     for (y = 0; y < h; y++) {
         for (x = 0; x < w; ) {
             int log2 = ff_log2_tab[show_bits(&gb, 8)];
-            int run = get_bits(&gb, runbits[log2]);
+            int run = get_bits(&gb, 14 - 4 * (log2 >> 1));
             int colour = get_bits(&gb, 2);
             run = FFMIN(run, w - x);
             // run length 0 means till end of row

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list