diff options
author | Baptiste Coudurier <[email protected]> | 2007-01-14 01:14:31 +0000 |
---|---|---|
committer | Baptiste Coudurier <[email protected]> | 2007-01-14 01:14:31 +0000 |
commit | 5b1e5dce35dfac3b89dddca851a0ffdeae4b9c20 (patch) | |
tree | efc20f2d703d2a1ddbd4c07158678562eda3275c | |
parent | 432cef7605b3a6aea3ff55062eb85517c43a7e7c (diff) |
swf can contain only one audio track, simplify
Originally committed as revision 7456 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/swf.c | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/libavformat/swf.c b/libavformat/swf.c index f07afab266..149406daa8 100644 --- a/libavformat/swf.c +++ b/libavformat/swf.c @@ -59,7 +59,7 @@ #include <assert.h> typedef struct { - + int audio_stream_index; offset_t duration_pos; offset_t tag_pos; @@ -808,8 +808,9 @@ static int swf_read_header(AVFormatContext *s, AVFormatParameters *ap) get_byte(pb); v = get_byte(pb); swf->samples_per_frame = get_le16(pb); - ast = av_new_stream(s, 1); + ast = av_new_stream(s, -1); /* -1 to avoid clash with video stream ch_id */ av_set_pts_info(ast, 24, 1, 1000); /* 24 bit pts in ms */ + swf->audio_stream_index = ast->index; ast->codec->channels = 1 + (v&1); ast->codec->codec_type = CODEC_TYPE_AUDIO; if (v & 0x20) @@ -866,14 +867,12 @@ static int swf_read_packet(AVFormatContext *s, AVPacket *pkt) } url_fskip(pb, len-2); } else if (tag == TAG_STREAMBLOCK) { - for( i=0; i<s->nb_streams; i++ ) { - st = s->streams[i]; - if (st->id == 1) { - url_fskip(pb, 4); - av_get_packet(pb, pkt, len-4); - pkt->stream_index = st->index; - return pkt->size; - } + st = s->streams[swf->audio_stream_index]; + if (st->codec->codec_id == CODEC_ID_MP3) { + url_fskip(pb, 4); + av_get_packet(pb, pkt, len-4); + pkt->stream_index = st->index; + return pkt->size; } url_fskip(pb, len); } else { |