]> git.sesse.net Git - vlc/commitdiff
RTP: support for overriding the TS demux - fixes #2103
authorRémi Denis-Courmont <rdenis@simphalempin.com>
Wed, 24 Sep 2008 17:43:49 +0000 (20:43 +0300)
committerRémi Denis-Courmont <rdenis@simphalempin.com>
Wed, 24 Sep 2008 18:08:10 +0000 (21:08 +0300)
modules/demux/rtp.c

index 1d819b435223b2ff7c8f8d3ee5fbecdec5dd3825..fd9e812a90be43d3c1c06d244af33d2fb9f37be5 100644 (file)
     "RTP packets will be discarded if they are too far behind (i.e. in the " \
     "past) by this many packets from the last received packet." )
 
+#define RTP_TS_DEMUX_TEXT N_("Demux module for TS over RTP")
+#define RTP_TS_DEMUX_LONGTEXT N_( \
+    "MPEG Transport Stream packets within an RTP stream will be handled by " \
+    "the specified demux module." )
+
 static int  Open (vlc_object_t *);
 static void Close (vlc_object_t *);
 
@@ -105,6 +110,9 @@ vlc_module_begin ();
                  RTP_MAX_MISORDER_LONGTEXT, true);
         change_integer_range (0, 32767);
 
+    add_module ("rtp-ts-demux", "demux", "ts", NULL, RTP_TS_DEMUX_TEXT,
+                RTP_TS_DEMUX_LONGTEXT, true);
+
     add_shortcut ("dccp");
     /*add_shortcut ("sctp");*/
     add_shortcut ("rtptcp"); /* "tcp" is already taken :( */
@@ -609,7 +617,14 @@ static void mpv_decode (demux_t *demux, void *data, block_t *block)
  */
 static void *ts_init (demux_t *demux)
 {
-    return stream_init (demux, "ts");
+    char *ts_demux = var_CreateGetNonEmptyString (demux, "rtp-ts-demux");
+    msg_Dbg (demux, "using %s chained demux", ts_demux);
+    if (!ts_demux)
+        return NULL;
+
+    void *stream = stream_init (demux, ts_demux);
+    free (ts_demux);
+    return stream;
 }