# HG changeset patch # User nicodvb # Date 1193512543 0 # Node ID 3dacff6ae67c131c5c161d803910b66c5737fca3 # Parent 4559076416de4c997c9255f5d07743ead6ea9df1 implemented DEMUXER_CTRL_IDENTIFY_PROGRAM to permit program switching diff -r 4559076416de -r 3dacff6ae67c libmpdemux/demux_lavf.c --- a/libmpdemux/demux_lavf.c Sat Oct 27 19:12:59 2007 +0000 +++ b/libmpdemux/demux_lavf.c Sat Oct 27 19:15:43 2007 +0000 @@ -707,6 +707,60 @@ return DEMUXER_CTRL_OK; } } + case DEMUXER_CTRL_IDENTIFY_PROGRAM: + { + demux_program_t *prog = arg; + AVProgram *program; + int p, i; + + if(priv->avfc->nb_programs < 2) + return DEMUXER_CTRL_NOTIMPL; + + if(prog->progid == -1) + { + p = 0; + while(pavfc->nb_programs && priv->avfc->programs[p]->id != priv->cur_program) + p++; + p = (p + 1) % priv->avfc->nb_programs; + } + else + { + for(i=0; iavfc->nb_programs; i++) + if(priv->avfc->programs[i]->id == prog->progid) + break; + if(i==priv->avfc->nb_programs) + return DEMUXER_CTRL_NOTIMPL; + p = i; + } + prog->vid = prog->aid = prog->sid = -2; //no audio and no video by default +redo: + program = priv->avfc->programs[p]; + for(i=0; inb_stream_indexes; i++) + { + switch(priv->avfc->streams[program->stream_index[i]]->codec->codec_type) + { + case CODEC_TYPE_VIDEO: + if(prog->vid == -2) + prog->vid = program->stream_index[i]; + break; + case CODEC_TYPE_AUDIO: + if(prog->aid == -2) + prog->aid = program->stream_index[i]; + break; + case CODEC_TYPE_SUBTITLE: + if(prog->sid == -2 && priv->avfc->streams[program->stream_index[i]]->codec->codec_id == CODEC_ID_TEXT) + prog->sid = program->stream_index[i]; + break; + } + } + if(prog->progid == -1 && prog->vid == -2 && prog->aid == -2) + { + p = (p + 1) % priv->avfc->nb_programs; + goto redo; + } + priv->cur_program = prog->progid = program->id; + return DEMUXER_CTRL_OK; + } default: return DEMUXER_CTRL_NOTIMPL; }