OSDN Git Service

warn use if edit list is not starting at 0, a/v desync might occur
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>
Wed, 13 Feb 2008 10:58:16 +0000 (10:58 +0000)
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>
Wed, 13 Feb 2008 10:58:16 +0000 (10:58 +0000)
Originally committed as revision 11923 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavformat/mov.c

index 12bfec1..0869dad 100644 (file)
@@ -1230,9 +1230,13 @@ static int mov_read_elst(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom)
     edit_count= sc->edit_count = get_be32(pb);     /* entries */
 
     for(i=0; i<edit_count; i++){
+        int time;
         get_be32(pb); /* Track duration */
-        get_be32(pb); /* Media time */
+        time = get_be32(pb); /* Media time */
         get_be32(pb); /* Media rate */
+        if (time != 0)
+            av_log(c->fc, AV_LOG_WARNING, "edit list not starting at 0, "
+                   "a/v desync might occur, patch welcome\n");
     }
     dprintf(c->fc, "track[%i].edit_count = %i\n", c->fc->nb_streams-1, sc->edit_count);
     return 0;