@ -366,6 +366,11 @@ static AVStream *create_stream(AVFormatContext *s, int stream_type){
st - > codec - > codec_id = CODEC_ID_NONE ; // Going to rely on copy for now
av_log ( s , AV_LOG_DEBUG , " Data stream created \n " ) ;
}
if ( s - > nb_streams > = 3 | | ( s - > nb_streams = = 2
& & s - > streams [ 0 ] - > codec - > codec_type ! = AVMEDIA_TYPE_DATA
& & s - > streams [ 1 ] - > codec - > codec_type ! = AVMEDIA_TYPE_DATA ) )
s - > ctx_flags & = ~ AVFMTCTX_NOHEADER ;
avpriv_set_pts_info ( st , 32 , 1 , 1000 ) ; /* 32 bit pts in ms */
return st ;
}
@ -383,9 +388,6 @@ static int flv_read_header(AVFormatContext *s,
flags = FLV_HEADER_FLAG_HASVIDEO | FLV_HEADER_FLAG_HASAUDIO ;
av_log ( s , AV_LOG_WARNING , " Broken FLV file, which says no streams present, this might fail \n " ) ;
}
if ( ( flags & ( FLV_HEADER_FLAG_HASVIDEO | FLV_HEADER_FLAG_HASAUDIO ) )
! = ( FLV_HEADER_FLAG_HASVIDEO | FLV_HEADER_FLAG_HASAUDIO ) )
s - > ctx_flags | = AVFMTCTX_NOHEADER ;
if ( flags & FLV_HEADER_FLAG_HASVIDEO ) {
@ -484,7 +486,6 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
if ( i = = s - > nb_streams ) {
av_log ( s , AV_LOG_WARNING , " Stream discovered after head already parsed \n " ) ;
st = create_stream ( s , stream_type ) ;
s - > ctx_flags & = ~ AVFMTCTX_NOHEADER ;
}
av_dlog ( s , " %d %X %d \n " , stream_type , flags , st - > discard ) ;
if ( ( st - > discard > = AVDISCARD_NONKEY & & ! ( ( flags & FLV_VIDEO_FRAMETYPE_MASK ) = = FLV_FRAME_KEY | | ( stream_type = = FLV_STREAM_TYPE_AUDIO ) ) )