summaryrefslogtreecommitdiffstats
path: root/libmpdemux
diff options
context:
space:
mode:
authorcehoyos <cehoyos@b3059339-0415-0410-9bf9-f77b7e298cf2>2007-12-02 18:04:14 +0000
committercehoyos <cehoyos@b3059339-0415-0410-9bf9-f77b7e298cf2>2007-12-02 18:04:14 +0000
commit8d5573a14e1e52ad590755ac25ea82ee3d911aa1 (patch)
tree05f3e1c1349e94bd62542c57e622d27c3d48e6b5 /libmpdemux
parent330359f85b70d541ee480c0a3a7d1400649efa75 (diff)
downloadmpv-8d5573a14e1e52ad590755ac25ea82ee3d911aa1.tar.bz2
mpv-8d5573a14e1e52ad590755ac25ea82ee3d911aa1.tar.xz
Fix playback of streams with more than one video track (only one supported).
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@25265 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpdemux')
-rw-r--r--libmpdemux/demux_rtp.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/libmpdemux/demux_rtp.cpp b/libmpdemux/demux_rtp.cpp
index ba9c77a0c3..3ba634e2cb 100644
--- a/libmpdemux/demux_rtp.cpp
+++ b/libmpdemux/demux_rtp.cpp
@@ -164,7 +164,7 @@ extern "C" demuxer_t* demux_open_rtp(demuxer_t* demuxer) {
rtpState->firstSyncTime.tv_sec = rtpState->firstSyncTime.tv_usec = 0;
demuxer->priv = rtpState;
- int audiofound = 0;
+ int audiofound = 0, videofound = 0;
// Create RTP receivers (sources) for each subsession:
MediaSubsessionIterator iter(*mediaSession);
MediaSubsession* subsession;
@@ -178,6 +178,10 @@ extern "C" demuxer_t* demux_open_rtp(demuxer_t* demuxer) {
}
desiredReceiveBufferSize = 100000;
} else if (strcmp(subsession->mediumName(), "video") == 0) {
+ if (videofound) {
+ fprintf(stderr, "Additional subsession \"video/%s\" skipped\n", subsession->codecName());
+ continue;
+ }
desiredReceiveBufferSize = 2000000;
} else {
continue;
@@ -210,6 +214,8 @@ extern "C" demuxer_t* demux_open_rtp(demuxer_t* demuxer) {
rtspStreamOverTCP)) break;
if (!strcmp(subsession->mediumName(), "audio"))
audiofound = 1;
+ if (!strcmp(subsession->mediumName(), "video"))
+ videofound = 1;
}
}
}