aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/flvdec.c
diff options
context:
space:
mode:
authorNazo <lovesyao@aol.com>2006-09-17 09:39:49 +0000
committerBenjamin Larsson <banan@ludd.ltu.se>2006-09-17 09:39:49 +0000
commitaeb20f7f9d37f38cd7df94158b19999a13ba5a12 (patch)
tree4f89fdd84405a4addce0f8fe3c33595c5990b413 /libavformat/flvdec.c
parente66477afbe0d3d48852b513c95497809a2fc2739 (diff)
downloadffmpeg-aeb20f7f9d37f38cd7df94158b19999a13ba5a12.tar.gz
FLV seeking patch by Nazo. lovesyao at aol com.
Originally committed as revision 6285 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/flvdec.c')
-rw-r--r--libavformat/flvdec.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/libavformat/flvdec.c b/libavformat/flvdec.c
index 0746fffcfe..9f9c33496f 100644
--- a/libavformat/flvdec.c
+++ b/libavformat/flvdec.c
@@ -55,15 +55,18 @@ static int flv_read_header(AVFormatContext *s,
url_fseek(&s->pb, offset, SEEK_SET);
+ s->start_time = 0;
+
return 0;
}
static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
{
- int ret, i, type, size, pts, flags, is_audio, next;
+ int ret, i, type, size, pts, flags, is_audio, next, pos;
AVStream *st = NULL;
for(;;){
+ pos = url_ftell(&s->pb);
url_fskip(&s->pb, 4); /* size of previous packet */
type = get_byte(&s->pb);
size = get_be24(&s->pb);
@@ -154,6 +157,8 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
url_fseek(&s->pb, next, SEEK_SET);
continue;
}
+ if ((flags >> 4)==1)
+ av_add_index_entry(st, pos, pts, size, 0, AVINDEX_KEYFRAME);
break;
}
@@ -216,6 +221,17 @@ static int flv_read_close(AVFormatContext *s)
return 0;
}
+static int flv_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp, int flags)
+{
+ AVStream *st = s->streams[stream_index];
+ int index = av_index_search_timestamp(st, timestamp, flags);
+ if (index < 0)
+ return -1;
+ url_fseek(&s->pb, st->index_entries[index].pos, SEEK_SET);
+
+ return 0;
+}
+
AVInputFormat flv_demuxer = {
"flv",
"flv format",
@@ -224,6 +240,7 @@ AVInputFormat flv_demuxer = {
flv_read_header,
flv_read_packet,
flv_read_close,
+ flv_read_seek,
.extensions = "flv",
.value = CODEC_ID_FLV1,
};