2 * Copyright (C) 2013 Collabora Ltd.
3 * Author: Sebastian Dröge <sebastian.droege@collabora.co.uk>
4 * Copyright (C) 2013 Sebastian Dröge <slomo@circular-chaos.org>
6 * gstcontext.h: Header for GstContext subsystem
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Library General Public
10 * License as published by the Free Software Foundation; either
11 * version 2 of the License, or (at your option) any later version.
13 * This library is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Library General Public License for more details.
18 * You should have received a copy of the GNU Library General Public
19 * License along with this library; if not, write to the
20 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
21 * Boston, MA 02110-1301, USA.
26 * @short_description: Lightweight objects to represent element contexts
27 * @see_also: #GstMiniObject, #GstElement
29 * #GstContext is a container object used to store contexts like a device
30 * context, a display server connection and similar concepts that should
31 * be shared between multiple elements.
33 * Applications can set a context on a complete pipeline by using
34 * gst_element_set_context(), which will then be propagated to all
35 * child elements. Elements can handle these in GstElement::set_context()
36 * and merge them with the context information they already have.
38 * When an element needs a context it will do the following actions in this
39 * order until one step succeeds:
40 * 1) Check if the element already has a context
41 * 2) Query downstream with GST_QUERY_CONTEXT for the context
42 * 2) Query upstream with GST_QUERY_CONTEXT for the context
43 * 3) Post a GST_MESSAGE_NEED_CONTEXT message on the bus with the required
44 * context types and afterwards check if a usable context was set now
45 * 4) Create a context by itself and post a GST_MESSAGE_HAVE_CONTEXT message
48 * Bins will catch GST_MESSAGE_NEED_CONTEXT messages and will set any previously
49 * known context on the element that asks for it if possible. Otherwise the
50 * application should provide one if it can.
55 #include "gst_private.h"
57 #include "gstcontext.h"
62 GstMiniObject mini_object;
65 GstStructure *structure;
69 #define GST_CONTEXT_STRUCTURE(c) (((GstContext *)(c))->structure)
71 static GType _gst_context_type = 0;
72 GST_DEFINE_MINI_OBJECT_TYPE (GstContext, gst_context);
75 _priv_gst_context_initialize (void)
77 GST_CAT_INFO (GST_CAT_GST_INIT, "init contexts");
79 /* the GstMiniObject types need to be class_ref'd once before it can be
80 * done from multiple threads;
81 * see http://bugzilla.gnome.org/show_bug.cgi?id=304551 */
82 gst_context_get_type ();
84 _gst_context_type = gst_context_get_type ();
88 _gst_context_free (GstContext * context)
90 GstStructure *structure;
92 g_return_if_fail (context != NULL);
94 GST_CAT_LOG (GST_CAT_CONTEXT, "finalize context %p: %" GST_PTR_FORMAT,
95 context, GST_CONTEXT_STRUCTURE (context));
97 structure = GST_CONTEXT_STRUCTURE (context);
99 gst_structure_set_parent_refcount (structure, NULL);
100 gst_structure_free (structure);
103 g_slice_free1 (sizeof (GstContext), context);
106 static void gst_context_init (GstContext * context);
109 _gst_context_copy (GstContext * context)
112 GstStructure *structure;
114 GST_CAT_LOG (GST_CAT_CONTEXT, "copy context %p: %" GST_PTR_FORMAT, context,
115 GST_CONTEXT_STRUCTURE (context));
117 copy = g_slice_new0 (GstContext);
119 gst_context_init (copy);
121 copy->context_type = g_strdup (context->context_type);
123 structure = GST_CONTEXT_STRUCTURE (context);
124 GST_CONTEXT_STRUCTURE (copy) = gst_structure_copy (structure);
125 gst_structure_set_parent_refcount (GST_CONTEXT_STRUCTURE (copy),
126 ©->mini_object.refcount);
128 copy->persistent = context->persistent;
130 return GST_CONTEXT_CAST (copy);
134 gst_context_init (GstContext * context)
136 gst_mini_object_init (GST_MINI_OBJECT_CAST (context), 0, _gst_context_type,
137 (GstMiniObjectCopyFunction) _gst_context_copy, NULL,
138 (GstMiniObjectFreeFunction) _gst_context_free);
143 * @persistent: Persistent context
145 * Create a new context.
147 * Returns: (transfer full): The new context.
152 gst_context_new (const gchar * context_type, gboolean persistent)
155 GstStructure *structure;
157 g_return_val_if_fail (context_type != NULL, NULL);
159 context = g_slice_new0 (GstContext);
161 GST_CAT_LOG (GST_CAT_CONTEXT, "creating new context %p", context);
163 structure = gst_structure_new_id_empty (GST_QUARK (CONTEXT));
164 gst_structure_set_parent_refcount (structure, &context->mini_object.refcount);
165 gst_context_init (context);
167 context->context_type = g_strdup (context_type);
168 GST_CONTEXT_STRUCTURE (context) = structure;
169 context->persistent = persistent;
175 * gst_context_get_context_type:
176 * @context: The #GstContext.
178 * Get the type of @context.
180 * Returns: The type of the context.
185 gst_context_get_context_type (const GstContext * context)
187 g_return_val_if_fail (GST_IS_CONTEXT (context), NULL);
189 return context->context_type;
193 * gst_context_get_structure:
194 * @context: The #GstContext.
196 * Access the structure of the context.
198 * Returns: (transfer none): The structure of the context. The structure is
199 * still owned by the context, which means that you should not modify it,
200 * free it and that the pointer becomes invalid when you free the context.
205 gst_context_get_structure (const GstContext * context)
207 g_return_val_if_fail (GST_IS_CONTEXT (context), NULL);
209 return GST_CONTEXT_STRUCTURE (context);
213 * gst_context_writable_structure:
214 * @context: The #GstContext.
216 * Get a writable version of the structure.
218 * Returns: The structure of the context. The structure is still
219 * owned by the event, which means that you should not free it and
220 * that the pointer becomes invalid when you free the event.
221 * This function checks if @context is writable.
226 gst_context_writable_structure (GstContext * context)
228 g_return_val_if_fail (GST_IS_CONTEXT (context), NULL);
229 g_return_val_if_fail (gst_context_is_writable (context), NULL);
231 return GST_CONTEXT_STRUCTURE (context);
235 * gst_context_is_persistent:
236 * @context: The #GstContext.
238 * Check if @context is persistent.
240 * Returns: %TRUE if the context is persistent.
245 gst_context_is_persistent (const GstContext * context)
247 g_return_val_if_fail (GST_IS_CONTEXT (context), NULL);
249 return context->persistent;