# HG changeset patch # User nicodvb # Date 1164065461 0 # Node ID 6bc989360c8b165dd0c8825ed512e4f5ba5b4982 # Parent 7901c90ac6ac9cf6377b7d90c316222fe6a6760f check we aren't short of sh_videos before allocating another one and fail if the allocation doesn't succeed; added support for video stream switching diff -r 7901c90ac6ac -r 6bc989360c8b libmpdemux/demux_lavf.c --- a/libmpdemux/demux_lavf.c Mon Nov 20 21:03:46 2006 +0000 +++ b/libmpdemux/demux_lavf.c Mon Nov 20 23:31:01 2006 +0000 @@ -64,6 +64,7 @@ int video_streams; int64_t last_pts; int astreams[MAX_A_STREAMS]; + int vstreams[MAX_V_STREAMS]; }lavf_priv_t; extern void print_wave_header(WAVEFORMATEX *h, int verbose_level); @@ -310,10 +311,16 @@ st->discard= AVDISCARD_ALL; break;} case CODEC_TYPE_VIDEO:{ - BITMAPINFOHEADER *bih=calloc(sizeof(BITMAPINFOHEADER) + codec->extradata_size,1); - sh_video_t* sh_video=new_sh_video(demuxer, i); + sh_video_t* sh_video; + BITMAPINFOHEADER *bih; + if(priv->video_streams >= MAX_V_STREAMS) + break; + sh_video=new_sh_video(demuxer, i); + if(!sh_video) break; + priv->vstreams[priv->video_streams] = i; + priv->video_streams++; + bih=calloc(sizeof(BITMAPINFOHEADER) + codec->extradata_size,1); - priv->video_streams++; if(!codec->codec_tag) codec->codec_tag= codec_get_bmp_tag(codec->codec_id); if(!codec->codec_tag) @@ -477,16 +484,31 @@ *((int *)arg) = (int)((priv->last_pts - priv->avfc->start_time)*100 / priv->avfc->duration); return DEMUXER_CTRL_OK; case DEMUXER_CTRL_SWITCH_AUDIO: + case DEMUXER_CTRL_SWITCH_VIDEO: { int id = *((int*)arg); int newid = -2; int i, curridx = -2; + int nstreams, *pstreams; + demux_stream_t *ds; - if(demuxer->audio->id == -2) + if(cmd == DEMUXER_CTRL_SWITCH_VIDEO) + { + ds = demuxer->video; + nstreams = priv->video_streams; + pstreams = priv->vstreams; + } + else + { + ds = demuxer->audio; + nstreams = priv->audio_streams; + pstreams = priv->astreams; + } + if(ds->id == -2) return DEMUXER_CTRL_NOTIMPL; - for(i = 0; i < priv->audio_streams; i++) + for(i = 0; i < nstreams; i++) { - if(priv->astreams[i] == demuxer->audio->id) //current stream id + if(pstreams[i] == ds->id) //current stream id { curridx = i; break; @@ -495,14 +517,14 @@ if(id < 0) { - i = (curridx + 1) % priv->audio_streams; - newid = priv->astreams[i]; + i = (curridx + 1) % nstreams; + newid = pstreams[i]; } else { - for(i = 0; i < priv->audio_streams; i++) + for(i = 0; i < nstreams; i++) { - if(priv->astreams[i] == id) + if(pstreams[i] == id) { newid = id; break; @@ -513,9 +535,9 @@ return DEMUXER_CTRL_NOTIMPL; else { - ds_free_packs(demuxer->audio); - priv->avfc->streams[demuxer->audio->id]->discard = AVDISCARD_ALL; - *((int*)arg) = demuxer->audio->id = newid; + ds_free_packs(ds); + priv->avfc->streams[ds->id]->discard = AVDISCARD_ALL; + *((int*)arg) = ds->id = newid; priv->avfc->streams[newid]->discard = AVDISCARD_NONE; return DEMUXER_CTRL_OK; }