[SCM] libav/experimental: If missing, calculate width or height from bpp and image size lowering the probe score too.

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 16:53:14 UTC 2013


The following commit has been merged in the experimental branch:
commit 9cf6bbb9936b8afed2ef3e8ab2a462fa7f537a4f
Author: Reynaldo H. Verdejo Pinochet <reynaldo at opendot.cl>
Date:   Sun Oct 18 23:56:00 2009 +0000

    If missing, calculate width or height from bpp and
    image size lowering the probe score too.
    
    Originally committed as revision 20304 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavformat/mtv.c b/libavformat/mtv.c
index ef07e4a..0547430 100644
--- a/libavformat/mtv.c
+++ b/libavformat/mtv.c
@@ -61,6 +61,15 @@ static int mtv_probe(AVProbeData *p)
     if(!(p->buf[51] && AV_RL16(&p->buf[52]) | AV_RL16(&p->buf[54])))
         return 0;
 
+    /* If width or height are 0 then imagesize header field should not */
+    if(AV_RL16(&p->buf[52]) && AV_RL16(&p->buf[54]))
+    {
+        if(!!AV_RL16(&p->buf[56]))
+            return AVPROBE_SCORE_MAX/2;
+        else
+            return 0;
+    }
+
     return AVPROBE_SCORE_MAX;
 }
 
@@ -82,6 +91,17 @@ static int mtv_read_header(AVFormatContext *s, AVFormatParameters *ap)
     mtv->img_width         = get_le16(pb);
     mtv->img_height        = get_le16(pb);
     mtv->img_segment_size  = get_le16(pb);
+
+    /* Calculate width and height if missing from header */
+
+    if(!mtv->img_width)
+        mtv->img_width=mtv->img_segment_size / (mtv->img_bpp>>3)
+                        / mtv->img_height;
+
+    if(!mtv->img_height)
+        mtv->img_height=mtv->img_segment_size / (mtv->img_bpp>>3)
+                        / mtv->img_width;
+
     url_fskip(pb, 4);
     audio_subsegments = get_le16(pb);
     mtv->full_segment_size =

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list