# HG changeset patch # User arpi # Date 1032992351 0 # Node ID 20910550332f0656f63ec5e90dd744a3451af11b # Parent 5dd2cdd760faa8a3d716375289ad565e28b4ab48 fixed invalid -aid/-vid segfault diff -r 5dd2cdd760fa -r 20910550332f libmpdemux/demux_avi.c --- a/libmpdemux/demux_avi.c Wed Sep 25 21:41:42 2002 +0000 +++ b/libmpdemux/demux_avi.c Wed Sep 25 22:19:11 2002 +0000 @@ -445,6 +445,16 @@ //---- AVI header: read_avi_header(demuxer,(demuxer->stream->type!=STREAMTYPE_STREAM)?index_mode:-2); + + if(demuxer->audio->id>=0 && !demuxer->a_streams[demuxer->audio->id]){ + mp_msg(MSGT_DEMUX,MSGL_WARN,"AVI: invalid audio stream ID: %d - ignoring (nosound)\n",demuxer->audio->id); + demuxer->audio->id=-2; // disabled + } + if(demuxer->video->id>=0 && !demuxer->v_streams[demuxer->video->id]){ + mp_msg(MSGT_DEMUX,MSGL_WARN,"AVI: invalid video stream ID: %d - ignoring (using default)\n",demuxer->video->id); + demuxer->video->id=-1; // autodetect + } + stream_reset(demuxer->stream); stream_seek(demuxer->stream,demuxer->movi_start); priv->idx_pos=0; @@ -518,7 +528,6 @@ if(!ds_fill_buffer(d_video)){ mp_msg(MSGT_DEMUX,MSGL_ERR,"AVI: " MSGTR_MissingVideoStreamBug); return NULL; -// GUI_MSG( mplAVIErrorMissingVideoStream ) } sh_video=d_video->sh;sh_video->ds=d_video; if(d_audio->id!=-2){