Include ONVIF types from single-include rtsp-server.h
authorSebastian Dröge <sebastian@centricular.com>
Thu, 1 Nov 2018 08:18:22 +0000 (10:18 +0200)
committerSebastian Dröge <sebastian@centricular.com>
Thu, 1 Nov 2018 08:18:22 +0000 (10:18 +0200)
... by actually making it a single-include header and moving everything
related to the GstRTSPServer type to rtsp-server-object.h instead.
Otherwise there are too many circular includes.

https://bugzilla.gnome.org/show_bug.cgi?id=797361

gst/rtsp-server/Makefile.am
gst/rtsp-server/meson.build
gst/rtsp-server/rtsp-context.h
gst/rtsp-server/rtsp-onvif-server.c
gst/rtsp-server/rtsp-onvif-server.h
gst/rtsp-server/rtsp-server-object.h [new file with mode: 0644]
gst/rtsp-server/rtsp-server-prelude.h
gst/rtsp-server/rtsp-server.c
gst/rtsp-server/rtsp-server.h
gst/rtsp-server/rtsp-session.h

index 59e214a..112e529 100644 (file)
@@ -18,6 +18,7 @@ public_headers = \
                rtsp-token.h \
                rtsp-client.h \
                rtsp-server.h \
+               rtsp-server-object.h \
                rtsp-server-prelude.h \
                rtsp-onvif-server.h \
                rtsp-onvif-client.h \
index 143385f..27cf384 100644 (file)
@@ -41,6 +41,7 @@ rtsp_server_headers = [
   'rtsp-token.h',
   'rtsp-client.h',
   'rtsp-server.h',
+  'rtsp-server-object.h',
   'rtsp-server-prelude.h',
 ]
 install_headers(rtsp_server_headers, subdir : 'gstreamer-1.0/gst/rtsp-server')
index dcd2f9b..c4567f9 100644 (file)
@@ -30,7 +30,7 @@ G_BEGIN_DECLS
 typedef struct _GstRTSPContext GstRTSPContext;
 
 #include "rtsp-server-prelude.h"
-#include "rtsp-server.h"
+#include "rtsp-server-object.h"
 #include "rtsp-media.h"
 #include "rtsp-media-factory.h"
 #include "rtsp-session-media.h"
index 3c3c6f4..704d8b2 100644 (file)
@@ -35,6 +35,7 @@
 #include "config.h"
 #endif
 
+#include "rtsp-context.h"
 #include "rtsp-onvif-server.h"
 #include "rtsp-onvif-client.h"
 
index f9d8e48..f9f1836 100644 (file)
@@ -21,7 +21,7 @@
 #define __GST_RTSP_ONVIF_SERVER_H__
 
 #include <gst/gst.h>
-#include "rtsp-server.h"
+#include "rtsp-server-object.h"
 
 #define GST_TYPE_RTSP_ONVIF_SERVER              (gst_rtsp_onvif_server_get_type ())
 #define GST_IS_RTSP_ONVIF_SERVER(obj)           (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_RTSP_ONVIF_SERVER))
diff --git a/gst/rtsp-server/rtsp-server-object.h b/gst/rtsp-server/rtsp-server-object.h
new file mode 100644 (file)
index 0000000..9827f99
--- /dev/null
@@ -0,0 +1,205 @@
+/* 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.
+ */
+
+#ifndef __GST_RTSP_SERVER_H__
+#define __GST_RTSP_SERVER_H__
+
+#include <gst/gst.h>
+
+G_BEGIN_DECLS
+
+#include "rtsp-server-prelude.h"
+#include "rtsp-session-pool.h"
+#include "rtsp-session.h"
+#include "rtsp-media.h"
+#include "rtsp-stream.h"
+#include "rtsp-stream-transport.h"
+#include "rtsp-address-pool.h"
+#include "rtsp-thread-pool.h"
+#include "rtsp-client.h"
+#include "rtsp-context.h"
+#include "rtsp-mount-points.h"
+#include "rtsp-media-factory.h"
+#include "rtsp-permissions.h"
+#include "rtsp-auth.h"
+#include "rtsp-token.h"
+#include "rtsp-session-media.h"
+#include "rtsp-sdp.h"
+#include "rtsp-media-factory-uri.h"
+#include "rtsp-params.h"
+
+typedef struct _GstRTSPServer GstRTSPServer;
+typedef struct _GstRTSPServerClass GstRTSPServerClass;
+typedef struct _GstRTSPServerPrivate GstRTSPServerPrivate;
+
+#define GST_TYPE_RTSP_SERVER              (gst_rtsp_server_get_type ())
+#define GST_IS_RTSP_SERVER(obj)           (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_RTSP_SERVER))
+#define GST_IS_RTSP_SERVER_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GST_TYPE_RTSP_SERVER))
+#define GST_RTSP_SERVER_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GST_TYPE_RTSP_SERVER, GstRTSPServerClass))
+#define GST_RTSP_SERVER(obj)              (G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_TYPE_RTSP_SERVER, GstRTSPServer))
+#define GST_RTSP_SERVER_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GST_TYPE_RTSP_SERVER, GstRTSPServerClass))
+#define GST_RTSP_SERVER_CAST(obj)         ((GstRTSPServer*)(obj))
+#define GST_RTSP_SERVER_CLASS_CAST(klass) ((GstRTSPServerClass*)(klass))
+
+/**
+ * GstRTSPServer:
+ *
+ * This object listens on a port, creates and manages the clients connected to
+ * it.
+ */
+struct _GstRTSPServer {
+  GObject      parent;
+
+  /*< private >*/
+  GstRTSPServerPrivate *priv;
+  gpointer _gst_reserved[GST_PADDING];
+};
+
+/**
+ * GstRTSPServerClass:
+ * @create_client: Create, configure a new GstRTSPClient
+ *          object that handles the new connection on @socket. The default
+ *          implementation will create a GstRTSPClient and will configure the
+ *          mount-points, auth, session-pool and thread-pool on the client.
+ * @client_connected: emitted when a new client connected.
+ *
+ * The RTSP server class structure
+ */
+struct _GstRTSPServerClass {
+  GObjectClass  parent_class;
+
+  GstRTSPClient * (*create_client)      (GstRTSPServer *server);
+
+  /* signals */
+  void            (*client_connected)   (GstRTSPServer *server, GstRTSPClient *client);
+
+  /*< private >*/
+  gpointer         _gst_reserved[GST_PADDING_LARGE];
+};
+
+GST_RTSP_SERVER_API
+GType                 gst_rtsp_server_get_type             (void);
+
+GST_RTSP_SERVER_API
+GstRTSPServer *       gst_rtsp_server_new                  (void);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_address          (GstRTSPServer *server, const gchar *address);
+
+GST_RTSP_SERVER_API
+gchar *               gst_rtsp_server_get_address          (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_service          (GstRTSPServer *server, const gchar *service);
+
+GST_RTSP_SERVER_API
+gchar *               gst_rtsp_server_get_service          (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_backlog          (GstRTSPServer *server, gint backlog);
+
+GST_RTSP_SERVER_API
+gint                  gst_rtsp_server_get_backlog          (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+int                   gst_rtsp_server_get_bound_port       (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_session_pool     (GstRTSPServer *server, GstRTSPSessionPool *pool);
+
+GST_RTSP_SERVER_API
+GstRTSPSessionPool *  gst_rtsp_server_get_session_pool     (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_mount_points     (GstRTSPServer *server, GstRTSPMountPoints *mounts);
+
+GST_RTSP_SERVER_API
+GstRTSPMountPoints *  gst_rtsp_server_get_mount_points     (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_auth             (GstRTSPServer *server, GstRTSPAuth *auth);
+
+GST_RTSP_SERVER_API
+GstRTSPAuth *         gst_rtsp_server_get_auth             (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+void                  gst_rtsp_server_set_thread_pool      (GstRTSPServer *server, GstRTSPThreadPool *pool);
+
+GST_RTSP_SERVER_API
+GstRTSPThreadPool *   gst_rtsp_server_get_thread_pool      (GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+gboolean              gst_rtsp_server_transfer_connection  (GstRTSPServer * server, GSocket *socket,
+                                                            const gchar * ip, gint port,
+                                                            const gchar *initial_buffer);
+
+GST_RTSP_SERVER_API
+gboolean              gst_rtsp_server_io_func              (GSocket *socket, GIOCondition condition,
+                                                            GstRTSPServer *server);
+
+GST_RTSP_SERVER_API
+GSocket *             gst_rtsp_server_create_socket        (GstRTSPServer *server,
+                                                            GCancellable  *cancellable,
+                                                            GError **error);
+
+GST_RTSP_SERVER_API
+GSource *             gst_rtsp_server_create_source        (GstRTSPServer *server,
+                                                            GCancellable * cancellable,
+                                                            GError **error);
+
+GST_RTSP_SERVER_API
+guint                 gst_rtsp_server_attach               (GstRTSPServer *server,
+                                                            GMainContext *context);
+
+/**
+ * GstRTSPServerClientFilterFunc:
+ * @server: a #GstRTSPServer object
+ * @client: a #GstRTSPClient in @server
+ * @user_data: user data that has been given to gst_rtsp_server_client_filter()
+ *
+ * This function will be called by the gst_rtsp_server_client_filter(). An
+ * implementation should return a value of #GstRTSPFilterResult.
+ *
+ * When this function returns #GST_RTSP_FILTER_REMOVE, @client will be removed
+ * from @server.
+ *
+ * A return value of #GST_RTSP_FILTER_KEEP will leave @client untouched in
+ * @server.
+ *
+ * A value of #GST_RTSP_FILTER_REF will add @client to the result #GList of
+ * gst_rtsp_server_client_filter().
+ *
+ * Returns: a #GstRTSPFilterResult.
+ */
+typedef GstRTSPFilterResult (*GstRTSPServerClientFilterFunc)  (GstRTSPServer *server,
+                                                               GstRTSPClient *client,
+                                                               gpointer user_data);
+
+GST_RTSP_SERVER_API
+GList *                gst_rtsp_server_client_filter    (GstRTSPServer *server,
+                                                         GstRTSPServerClientFilterFunc func,
+                                                         gpointer user_data);
+
+#ifdef G_DEFINE_AUTOPTR_CLEANUP_FUNC
+G_DEFINE_AUTOPTR_CLEANUP_FUNC(GstRTSPServer, gst_object_unref)
+#endif
+
+G_END_DECLS
+
+#endif /* __GST_RTSP_SERVER_H__ */
index ac4ad2c..8aff8c4 100644 (file)
 # endif
 #endif
 
+/* Do *not* use these defines outside of rtsp-server. Use G_DEPRECATED instead. */
+#ifdef GST_DISABLE_DEPRECATED
+#define GST_RTSP_SERVER_DEPRECATED GST_RTSP_SERVER_API
+#define GST_RTSP_SERVER_DEPRECATED_FOR(f) GST_RTSP_SERVER_API
+#else
+#define GST_RTSP_SERVER_DEPRECATED G_DEPRECATED GST_RTSP_SERVER_API
+#define GST_RTSP_SERVER_DEPRECATED_FOR(f) G_DEPRECATED_FOR(f) GST_RTSP_SERVER_API
+#endif
+
 #endif /* __GST_RTSP_SERVER_PRELUDE_H__ */
index de409e0..47b7187 100644 (file)
@@ -59,7 +59,8 @@
 #include <stdlib.h>
 #include <string.h>
 
-#include "rtsp-server.h"
+#include "rtsp-context.h"
+#include "rtsp-server-object.h"
 #include "rtsp-client.h"
 
 #define GST_RTSP_SERVER_GET_LOCK(server)  (&(GST_RTSP_SERVER_CAST(server)->priv->lock))
index 7364864..cda2a66 100644 (file)
 
 G_BEGIN_DECLS
 
-/* Do *not* use these defines outside of rtsp-server. Use G_DEPRECATED instead. */
-#ifdef GST_DISABLE_DEPRECATED
-#define GST_RTSP_SERVER_DEPRECATED GST_RTSP_SERVER_API
-#define GST_RTSP_SERVER_DEPRECATED_FOR(f) GST_RTSP_SERVER_API
-#else
-#define GST_RTSP_SERVER_DEPRECATED G_DEPRECATED GST_RTSP_SERVER_API
-#define GST_RTSP_SERVER_DEPRECATED_FOR(f) G_DEPRECATED_FOR(f) GST_RTSP_SERVER_API
-#endif
-
-typedef struct _GstRTSPServer GstRTSPServer;
-typedef struct _GstRTSPServerClass GstRTSPServerClass;
-typedef struct _GstRTSPServerPrivate GstRTSPServerPrivate;
-
 #include "rtsp-server-prelude.h"
 #include "rtsp-session-pool.h"
 #include "rtsp-session.h"
@@ -57,158 +44,12 @@ typedef struct _GstRTSPServerPrivate GstRTSPServerPrivate;
 #include "rtsp-sdp.h"
 #include "rtsp-media-factory-uri.h"
 #include "rtsp-params.h"
+#include "rtsp-server-object.h"
 
-#define GST_TYPE_RTSP_SERVER              (gst_rtsp_server_get_type ())
-#define GST_IS_RTSP_SERVER(obj)           (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_RTSP_SERVER))
-#define GST_IS_RTSP_SERVER_CLASS(klass)   (G_TYPE_CHECK_CLASS_TYPE ((klass), GST_TYPE_RTSP_SERVER))
-#define GST_RTSP_SERVER_GET_CLASS(obj)    (G_TYPE_INSTANCE_GET_CLASS ((obj), GST_TYPE_RTSP_SERVER, GstRTSPServerClass))
-#define GST_RTSP_SERVER(obj)              (G_TYPE_CHECK_INSTANCE_CAST ((obj), GST_TYPE_RTSP_SERVER, GstRTSPServer))
-#define GST_RTSP_SERVER_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GST_TYPE_RTSP_SERVER, GstRTSPServerClass))
-#define GST_RTSP_SERVER_CAST(obj)         ((GstRTSPServer*)(obj))
-#define GST_RTSP_SERVER_CLASS_CAST(klass) ((GstRTSPServerClass*)(klass))
-
-/**
- * GstRTSPServer:
- *
- * This object listens on a port, creates and manages the clients connected to
- * it.
- */
-struct _GstRTSPServer {
-  GObject      parent;
-
-  /*< private >*/
-  GstRTSPServerPrivate *priv;
-  gpointer _gst_reserved[GST_PADDING];
-};
-
-/**
- * GstRTSPServerClass:
- * @create_client: Create, configure a new GstRTSPClient
- *          object that handles the new connection on @socket. The default
- *          implementation will create a GstRTSPClient and will configure the
- *          mount-points, auth, session-pool and thread-pool on the client.
- * @client_connected: emitted when a new client connected.
- *
- * The RTSP server class structure
- */
-struct _GstRTSPServerClass {
-  GObjectClass  parent_class;
-
-  GstRTSPClient * (*create_client)      (GstRTSPServer *server);
-
-  /* signals */
-  void            (*client_connected)   (GstRTSPServer *server, GstRTSPClient *client);
-
-  /*< private >*/
-  gpointer         _gst_reserved[GST_PADDING_LARGE];
-};
-
-GST_RTSP_SERVER_API
-GType                 gst_rtsp_server_get_type             (void);
-
-GST_RTSP_SERVER_API
-GstRTSPServer *       gst_rtsp_server_new                  (void);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_address          (GstRTSPServer *server, const gchar *address);
-
-GST_RTSP_SERVER_API
-gchar *               gst_rtsp_server_get_address          (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_service          (GstRTSPServer *server, const gchar *service);
-
-GST_RTSP_SERVER_API
-gchar *               gst_rtsp_server_get_service          (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_backlog          (GstRTSPServer *server, gint backlog);
-
-GST_RTSP_SERVER_API
-gint                  gst_rtsp_server_get_backlog          (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-int                   gst_rtsp_server_get_bound_port       (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_session_pool     (GstRTSPServer *server, GstRTSPSessionPool *pool);
-
-GST_RTSP_SERVER_API
-GstRTSPSessionPool *  gst_rtsp_server_get_session_pool     (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_mount_points     (GstRTSPServer *server, GstRTSPMountPoints *mounts);
-
-GST_RTSP_SERVER_API
-GstRTSPMountPoints *  gst_rtsp_server_get_mount_points     (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_auth             (GstRTSPServer *server, GstRTSPAuth *auth);
-
-GST_RTSP_SERVER_API
-GstRTSPAuth *         gst_rtsp_server_get_auth             (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-void                  gst_rtsp_server_set_thread_pool      (GstRTSPServer *server, GstRTSPThreadPool *pool);
-
-GST_RTSP_SERVER_API
-GstRTSPThreadPool *   gst_rtsp_server_get_thread_pool      (GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-gboolean              gst_rtsp_server_transfer_connection  (GstRTSPServer * server, GSocket *socket,
-                                                            const gchar * ip, gint port,
-                                                            const gchar *initial_buffer);
-
-GST_RTSP_SERVER_API
-gboolean              gst_rtsp_server_io_func              (GSocket *socket, GIOCondition condition,
-                                                            GstRTSPServer *server);
-
-GST_RTSP_SERVER_API
-GSocket *             gst_rtsp_server_create_socket        (GstRTSPServer *server,
-                                                            GCancellable  *cancellable,
-                                                            GError **error);
-
-GST_RTSP_SERVER_API
-GSource *             gst_rtsp_server_create_source        (GstRTSPServer *server,
-                                                            GCancellable * cancellable,
-                                                            GError **error);
-
-GST_RTSP_SERVER_API
-guint                 gst_rtsp_server_attach               (GstRTSPServer *server,
-                                                            GMainContext *context);
-
-/**
- * GstRTSPServerClientFilterFunc:
- * @server: a #GstRTSPServer object
- * @client: a #GstRTSPClient in @server
- * @user_data: user data that has been given to gst_rtsp_server_client_filter()
- *
- * This function will be called by the gst_rtsp_server_client_filter(). An
- * implementation should return a value of #GstRTSPFilterResult.
- *
- * When this function returns #GST_RTSP_FILTER_REMOVE, @client will be removed
- * from @server.
- *
- * A return value of #GST_RTSP_FILTER_KEEP will leave @client untouched in
- * @server.
- *
- * A value of #GST_RTSP_FILTER_REF will add @client to the result #GList of
- * gst_rtsp_server_client_filter().
- *
- * Returns: a #GstRTSPFilterResult.
- */
-typedef GstRTSPFilterResult (*GstRTSPServerClientFilterFunc)  (GstRTSPServer *server,
-                                                               GstRTSPClient *client,
-                                                               gpointer user_data);
-
-GST_RTSP_SERVER_API
-GList *                gst_rtsp_server_client_filter    (GstRTSPServer *server,
-                                                         GstRTSPServerClientFilterFunc func,
-                                                         gpointer user_data);
-
-#ifdef G_DEFINE_AUTOPTR_CLEANUP_FUNC
-G_DEFINE_AUTOPTR_CLEANUP_FUNC(GstRTSPServer, gst_object_unref)
-#endif
+#include "rtsp-onvif-client.h"
+#include "rtsp-onvif-media-factory.h"
+#include "rtsp-onvif-media.h"
+#include "rtsp-onvif-server.h"
 
 G_END_DECLS
 
index 62d653a..e2a46e6 100644 (file)
@@ -20,7 +20,7 @@
 #include <gst/gst.h>
 
 #include <gst/rtsp/gstrtsptransport.h>
-#include "rtsp-server.h" /* for GST_RTSP_SERVER_DEPRECATED_FOR */
+#include "rtsp-server-prelude.h" /* for GST_RTSP_SERVER_DEPRECATED_FOR */
 
 #ifndef __GST_RTSP_SESSION_H__
 #define __GST_RTSP_SESSION_H__