]> git.sesse.net Git - ffmpeg/commitdiff
dynamic index building so forward and backward seeking in avi without an index is...
authorMichael Niedermayer <michaelni@gmx.at>
Mon, 5 Feb 2007 23:06:08 +0000 (23:06 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Mon, 5 Feb 2007 23:06:08 +0000 (23:06 +0000)
Originally committed as revision 7842 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavformat/avidec.c

index 273c20b449a70d5d1e650dacd5f545d1546c9cb2..90fc6b383f30be543bb73e483fd99661280c08c6 100644 (file)
@@ -626,9 +626,9 @@ resync:
             pkt->stream_index = avi->stream_index;
 
             if (st->codec->codec_type == CODEC_TYPE_VIDEO) {
-                if(st->index_entries){
                     AVIndexEntry *e;
                     int index;
+                assert(st->index_entries);
 
                     index= av_index_search_timestamp(st, pkt->dts, 0);
                     e= &st->index_entries[index];
@@ -637,11 +637,6 @@ resync:
                         if (e->flags & AVINDEX_KEYFRAME)
                             pkt->flags |= PKT_FLAG_KEY;
                     }
-                } else {
-                    /* if no index, better to say that all frames
-                        are key frames */
-                    pkt->flags |= PKT_FLAG_KEY;
-                }
             } else {
                 pkt->flags |= PKT_FLAG_KEY;
             }
@@ -735,6 +730,13 @@ resync:
             avi->stream_index= n;
             ast->packet_size= size + 8;
             ast->remaining= size;
+
+            {
+                uint64_t pos= url_ftell(pb) - 8;
+                if(!st->index_entries || !st->nb_index_entries || st->index_entries[st->nb_index_entries - 1].pos < pos){
+                    av_add_index_entry(st, pos, ast->frame_offset / FFMAX(1, ast->sample_size), size, 0, AVINDEX_KEYFRAME);
+                }
+            }
             goto resync;
           }
         }