examples: add another multicast example
authorWim Taymans <wim.taymans@collabora.co.uk>
Thu, 15 Nov 2012 15:52:42 +0000 (16:52 +0100)
committerWim Taymans <wim.taymans@collabora.co.uk>
Thu, 15 Nov 2012 15:52:42 +0000 (16:52 +0100)
Add an example for how to configure separate multicast ranges for each media
stream.

examples/Makefile.am
examples/test-multicast2.c [new file with mode: 0644]

index 32537a4..47b2cf9 100644 (file)
@@ -1,6 +1,6 @@
 noinst_PROGRAMS = test-video test-ogg test-mp4 test-readme \
                  test-launch test-sdp test-uri test-auth \
-                 test-multicast
+                 test-multicast test-multicast2
 
 #INCLUDES = -I$(top_srcdir) -I$(srcdir)
 
diff --git a/examples/test-multicast2.c b/examples/test-multicast2.c
new file mode 100644 (file)
index 0000000..7a95374
--- /dev/null
@@ -0,0 +1,125 @@
+/* GStreamer
+ * Copyright (C) 2008 Wim Taymans <wim.taymans at gmail.com>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+
+#include <gst/gst.h>
+
+#include <gst/rtsp-server/rtsp-server.h>
+
+
+static gboolean
+timeout (GstRTSPServer * server, gboolean ignored)
+{
+  GstRTSPSessionPool *pool;
+
+  pool = gst_rtsp_server_get_session_pool (server);
+  gst_rtsp_session_pool_cleanup (pool);
+  g_object_unref (pool);
+
+  return TRUE;
+}
+
+static void
+media_constructed (GstRTSPMediaFactory * factory, GstRTSPMedia * media)
+{
+  guint i, n_streams;
+
+  n_streams = gst_rtsp_media_n_streams (media);
+
+  for (i = 0; i < n_streams; i++) {
+    GstRTSPAddressPool *pool;
+    GstRTSPStream *stream;
+    gchar *min, *max;
+
+    stream = gst_rtsp_media_get_stream (media, i);
+
+    /* make a new address pool */
+    pool = gst_rtsp_address_pool_new ();
+
+    min = g_strdup_printf ("224.3.0.%d", (2 * i) + 1);
+    max = g_strdup_printf ("224.3.0.%d", (2 * i) + 2);
+    gst_rtsp_address_pool_add_range (pool, min, max,
+        5000 + (10 * i), 5010 + (10 * i), 1);
+    g_free (min);
+    g_free (max);
+
+    gst_rtsp_stream_set_address_pool (stream, pool);
+    g_object_unref (pool);
+  }
+}
+
+int
+main (int argc, char *argv[])
+{
+  GMainLoop *loop;
+  GstRTSPServer *server;
+  GstRTSPMediaMapping *mapping;
+  GstRTSPMediaFactory *factory;
+
+  gst_init (&argc, &argv);
+
+  loop = g_main_loop_new (NULL, FALSE);
+
+  /* create a server instance */
+  server = gst_rtsp_server_new ();
+
+  /* get the mapping for this server, every server has a default mapper object
+   * that be used to map uri mount points to media factories */
+  mapping = gst_rtsp_server_get_media_mapping (server);
+
+  /* make a media factory for a test stream. The default media factory can use
+   * gst-launch syntax to create pipelines. 
+   * any launch line works as long as it contains elements named pay%d. Each
+   * element with pay%d names will be a stream */
+  factory = gst_rtsp_media_factory_new ();
+  gst_rtsp_media_factory_set_launch (factory, "( "
+      "videotestsrc ! video/x-raw,width=352,height=288,framerate=15/1 ! "
+      "x264enc ! rtph264pay name=pay0 pt=96 "
+      "audiotestsrc ! audio/x-raw,rate=8000 ! "
+      "alawenc ! rtppcmapay name=pay1 pt=97 " ")");
+
+  gst_rtsp_media_factory_set_shared (factory, TRUE);
+
+  g_signal_connect (factory, "media-constructed", (GCallback)
+      media_constructed, NULL);
+
+  /* attach the test factory to the /test url */
+  gst_rtsp_media_mapping_add_factory (mapping, "/test", factory);
+
+  /* don't need the ref to the mapper anymore */
+  g_object_unref (mapping);
+
+  /* attach the server to the default maincontext */
+  if (gst_rtsp_server_attach (server, NULL) == 0)
+    goto failed;
+
+  g_timeout_add_seconds (2, (GSourceFunc) timeout, server);
+
+  /* start serving */
+  g_print ("stream ready at rtsp://127.0.0.1:8554/test\n");
+  g_main_loop_run (loop);
+
+  return 0;
+
+  /* ERRORS */
+failed:
+  {
+    g_print ("failed to attach the server\n");
+    return -1;
+  }
+}