[MPlayer-cvslog] r21116 - trunk/libmpdemux/demux_lavf.c
nicodvb
subversion at mplayerhq.hu
Tue Nov 21 00:31:01 CET 2006
Author: nicodvb
Date: Tue Nov 21 00:31:01 2006
New Revision: 21116
Modified:
trunk/libmpdemux/demux_lavf.c
Log:
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
Modified: trunk/libmpdemux/demux_lavf.c
==============================================================================
--- trunk/libmpdemux/demux_lavf.c (original)
+++ trunk/libmpdemux/demux_lavf.c Tue Nov 21 00:31:01 2006
@@ -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;
}
More information about the MPlayer-cvslog
mailing list