OSDN Git Service

fix ctts index computation when seeking, check must be done against next ctts sample...
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>
Sat, 12 May 2007 22:02:27 +0000 (22:02 +0000)
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>
Sat, 12 May 2007 22:02:27 +0000 (22:02 +0000)
Originally committed as revision 9007 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavformat/mov.c

index 5d38ebf..6f783b3 100644 (file)
@@ -1525,12 +1525,13 @@ static int mov_seek_stream(AVStream *st, int64_t timestamp, int flags)
     if (sc->ctts_data) {
         time_sample = 0;
         for (i = 0; i < sc->ctts_count; i++) {
-            time_sample += sc->ctts_data[i].count;
-            if (time_sample >= sc->current_sample) {
+            int next = time_sample + sc->ctts_data[i].count;
+            if (next > sc->current_sample) {
                 sc->sample_to_ctime_index = i;
-                sc->sample_to_ctime_sample = time_sample - sc->current_sample;
+                sc->sample_to_ctime_sample = sc->current_sample - time_sample;
                 break;
             }
+            time_sample = next;
         }
     }
     return sample;