2 * Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
3 * 2000 Wim Taymans <wtay@chello.be>
5 * gstpad.c: Pads for connecting elements together
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Library General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Library General Public License for more details.
17 * You should have received a copy of the GNU Library General Public
18 * License along with this library; if not, write to the
19 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20 * Boston, MA 02111-1307, USA.
23 /* #define GST_DEBUG_ENABLED */
24 #include "gst_private.h"
28 #include "gstelement.h"
31 #include "gstscheduler.h"
34 GType _gst_pad_type = 0;
36 /***** Start with the base GstPad class *****/
37 static void gst_pad_class_init (GstPadClass *klass);
38 static void gst_pad_init (GstPad *pad);
40 static gboolean gst_pad_try_reconnect_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad,
41 GstCaps *caps, gboolean clear);
43 #ifndef GST_DISABLE_LOADSAVE
44 static xmlNodePtr gst_pad_save_thyself (GstObject *object, xmlNodePtr parent);
47 static GstObject *pad_parent_class = NULL;
50 gst_pad_get_type(void)
53 static const GTypeInfo pad_info = {
57 (GClassInitFunc)gst_pad_class_init,
62 (GInstanceInitFunc)gst_pad_init,
65 _gst_pad_type = g_type_register_static(GST_TYPE_OBJECT, "GstPad", &pad_info, 0);
71 gst_pad_class_init (GstPadClass *klass)
73 pad_parent_class = g_type_class_ref(GST_TYPE_OBJECT);
77 gst_pad_init (GstPad *pad)
79 pad->element_private = NULL;
81 pad->padtemplate = NULL;
86 /***** Then do the Real Pad *****/
87 /* Pad signals and args */
91 REAL_CAPS_NEGO_FAILED,
105 static void gst_real_pad_class_init (GstRealPadClass *klass);
106 static void gst_real_pad_init (GstRealPad *pad);
108 static void gst_real_pad_set_property (GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec);
109 static void gst_real_pad_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec);
111 static void gst_real_pad_dispose (GObject *object);
113 static void gst_pad_push_func (GstPad *pad, GstBuffer *buf);
115 GType _gst_real_pad_type = 0;
117 static GstPad *real_pad_parent_class = NULL;
118 static guint gst_real_pad_signals[REAL_LAST_SIGNAL] = { 0 };
121 gst_real_pad_get_type(void) {
122 if (!_gst_real_pad_type) {
123 static const GTypeInfo pad_info = {
124 sizeof(GstRealPadClass),
127 (GClassInitFunc)gst_real_pad_class_init,
132 (GInstanceInitFunc)gst_real_pad_init,
135 _gst_real_pad_type = g_type_register_static(GST_TYPE_PAD, "GstRealPad", &pad_info, 0);
137 return _gst_real_pad_type;
141 gst_real_pad_class_init (GstRealPadClass *klass)
143 GObjectClass *gobject_class;
144 GstObjectClass *gstobject_class;
146 gobject_class = (GObjectClass*) klass;
147 gstobject_class = (GstObjectClass*) klass;
149 real_pad_parent_class = g_type_class_ref (GST_TYPE_PAD);
151 gobject_class->dispose = GST_DEBUG_FUNCPTR (gst_real_pad_dispose);
152 gobject_class->set_property = GST_DEBUG_FUNCPTR (gst_real_pad_set_property);
153 gobject_class->get_property = GST_DEBUG_FUNCPTR (gst_real_pad_get_property);
155 gst_real_pad_signals[REAL_SET_ACTIVE] =
156 g_signal_new ("set_active", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
157 G_STRUCT_OFFSET (GstRealPadClass, set_active), NULL, NULL,
158 gst_marshal_VOID__BOOLEAN, G_TYPE_NONE, 1,
160 gst_real_pad_signals[REAL_CAPS_CHANGED] =
161 g_signal_new ("caps_changed", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
162 G_STRUCT_OFFSET (GstRealPadClass, caps_changed), NULL, NULL,
163 gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
165 gst_real_pad_signals[REAL_CAPS_NEGO_FAILED] =
166 g_signal_new ("caps_nego_failed", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
167 G_STRUCT_OFFSET (GstRealPadClass, caps_nego_failed), NULL, NULL,
168 gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
170 gst_real_pad_signals[REAL_CONNECTED] =
171 g_signal_new ("connected", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
172 G_STRUCT_OFFSET (GstRealPadClass, connected), NULL, NULL,
173 gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
175 gst_real_pad_signals[REAL_DISCONNECTED] =
176 g_signal_new ("disconnected", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
177 G_STRUCT_OFFSET (GstRealPadClass, disconnected), NULL, NULL,
178 gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
180 gst_real_pad_signals[REAL_EVENT_RECEIVED] =
181 g_signal_new ("event_received", G_TYPE_FROM_CLASS (klass), G_SIGNAL_RUN_LAST,
182 G_STRUCT_OFFSET (GstRealPadClass, event_received), NULL, NULL,
183 gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
186 /* gtk_object_add_arg_type ("GstRealPad::active", G_TYPE_BOOLEAN, */
187 /* GTK_ARG_READWRITE, REAL_ARG_ACTIVE); */
188 g_object_class_install_property (G_OBJECT_CLASS (klass), REAL_ARG_ACTIVE,
189 g_param_spec_boolean ("active", "Active", "Whether the pad is active.",
190 TRUE,G_PARAM_READWRITE));
192 #ifndef GST_DISABLE_LOADSAVE
193 gstobject_class->save_thyself = GST_DEBUG_FUNCPTR (gst_pad_save_thyself);
195 gstobject_class->path_string_separator = ".";
199 gst_real_pad_init (GstRealPad *pad)
201 pad->direction = GST_PAD_UNKNOWN;
205 pad->sched_private = NULL;
207 pad->chainfunc = NULL;
209 pad->getregionfunc = NULL;
211 pad->chainhandler = GST_DEBUG_FUNCPTR (gst_pad_push_func);
212 pad->gethandler = NULL;
213 pad->pullregionfunc = NULL;
215 pad->bufferpoolfunc = NULL;
216 pad->ghostpads = NULL;
219 pad->connectfunc = NULL;
220 pad->getcapsfunc = NULL;
224 gst_real_pad_set_property (GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec)
226 g_return_if_fail (GST_IS_PAD (object));
229 case REAL_ARG_ACTIVE:
230 if (g_value_get_boolean (value)) {
231 GST_DEBUG (GST_CAT_PADS, "activating pad %s:%s\n", GST_DEBUG_PAD_NAME (object));
232 GST_FLAG_UNSET (object, GST_PAD_DISABLED);
234 GST_DEBUG (GST_CAT_PADS, "de-activating pad %s:%s\n", GST_DEBUG_PAD_NAME (object));
235 GST_FLAG_SET (object, GST_PAD_DISABLED);
237 g_signal_emit (G_OBJECT (object), gst_real_pad_signals[REAL_SET_ACTIVE], 0,
238 !GST_FLAG_IS_SET (object, GST_PAD_DISABLED));
246 gst_real_pad_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec)
248 /* it's not null if we got it, but it might not be ours */
249 g_return_if_fail (GST_IS_PAD (object));
252 case REAL_ARG_ACTIVE:
253 g_value_set_boolean (value, !GST_FLAG_IS_SET (object, GST_PAD_DISABLED));
263 * @name: name of new pad
264 * @direction: either GST_PAD_SRC or GST_PAD_SINK
266 * Create a new pad with given name.
271 gst_pad_new (gchar *name,
272 GstPadDirection direction)
276 g_return_val_if_fail (name != NULL, NULL);
277 g_return_val_if_fail (direction != GST_PAD_UNKNOWN, NULL);
279 pad = g_object_new (gst_real_pad_get_type (), NULL);
280 gst_object_set_name (GST_OBJECT (pad), name);
281 GST_RPAD_DIRECTION (pad) = direction;
283 return GST_PAD (pad);
287 * gst_pad_new_from_template:
288 * @templ: the pad template to use
289 * @name: the name of the element
291 * Create a new pad with given name from the given template.
296 gst_pad_new_from_template (GstPadTemplate *templ,
301 g_return_val_if_fail (name != NULL, NULL);
302 g_return_val_if_fail (templ != NULL, NULL);
304 pad = gst_pad_new (name, templ->direction);
306 gst_object_ref (GST_OBJECT (templ));
307 GST_PAD_PADTEMPLATE (pad) = templ;
313 * gst_pad_get_direction:
314 * @pad: the Pad to get the direction from
316 * Get the direction of the pad.
318 * Returns: the direction of the pad
321 gst_pad_get_direction (GstPad *pad)
323 g_return_val_if_fail (pad != NULL, GST_PAD_UNKNOWN);
324 g_return_val_if_fail (GST_IS_PAD (pad), GST_PAD_UNKNOWN);
326 return GST_PAD_DIRECTION (pad);
331 * @pad: the pad to set the name of
332 * @name: the name of the pad
334 * Set the name of a pad.
337 gst_pad_set_name (GstPad *pad,
340 g_return_if_fail (pad != NULL);
341 g_return_if_fail (GST_IS_PAD (pad));
343 gst_object_set_name (GST_OBJECT (pad), name);
348 * @pad: the pad to get the name of
350 * Get the name of a pad.
352 * Returns: the name of the pad, don't free.
355 gst_pad_get_name (GstPad *pad)
357 g_return_val_if_fail (pad != NULL, NULL);
358 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
360 return GST_OBJECT_NAME (pad);
364 * gst_pad_set_chain_function:
365 * @pad: the pad to set the chain function for
366 * @chain: the chain function
368 * Set the given chain function for the pad.
371 gst_pad_set_chain_function (GstPad *pad,
372 GstPadChainFunction chain)
374 g_return_if_fail (pad != NULL);
375 g_return_if_fail (GST_IS_REAL_PAD (pad));
377 GST_RPAD_CHAINFUNC(pad) = chain;
378 GST_DEBUG (GST_CAT_PADS, "chainfunc for %s:%s set to %s\n",
379 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (chain));
383 * gst_pad_set_get_function:
384 * @pad: the pad to set the get function for
385 * @get: the get function
387 * Set the given get function for the pad.
390 gst_pad_set_get_function (GstPad *pad,
391 GstPadGetFunction get)
393 g_return_if_fail (pad != NULL);
394 g_return_if_fail (GST_IS_REAL_PAD (pad));
396 GST_RPAD_GETFUNC(pad) = get;
397 GST_DEBUG (GST_CAT_PADS, "getfunc for %s:%s set to %s\n",
398 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (get));
402 * gst_pad_set_event_function:
403 * @pad: the pad to set the event handler for
404 * @event: the event handler
406 * Set the given event handler for the pad.
409 gst_pad_set_event_function (GstPad *pad,
410 GstPadEventFunction event)
412 g_return_if_fail (pad != NULL);
413 g_return_if_fail (GST_IS_REAL_PAD (pad));
415 GST_RPAD_EVENTFUNC(pad) = event;
416 GST_DEBUG (GST_CAT_PADS, "eventfunc for %s:%s set to %s\n",
417 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (event));
421 * gst_pad_set_getregion_function:
422 * @pad: the pad to set the getregion function for
423 * @getregion: the getregion function
425 * Set the given getregion function for the pad.
428 gst_pad_set_getregion_function (GstPad *pad,
429 GstPadGetRegionFunction getregion)
431 g_return_if_fail (pad != NULL);
432 g_return_if_fail (GST_IS_REAL_PAD (pad));
434 GST_RPAD_GETREGIONFUNC(pad) = getregion;
435 GST_DEBUG (GST_CAT_PADS, "getregionfunc for %s:%s set to %s\n",
436 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (getregion));
440 * gst_pad_set_connect_function:
441 * @pad: the pad to set the connect function for
442 * @connect: the connect function
444 * Set the given connect function for the pad. It will be called
445 * when the pad is connected or reconnected with caps.
448 gst_pad_set_connect_function (GstPad *pad,
449 GstPadConnectFunction connect)
451 g_return_if_fail (pad != NULL);
452 g_return_if_fail (GST_IS_REAL_PAD (pad));
454 GST_RPAD_CONNECTFUNC (pad) = connect;
455 GST_DEBUG (GST_CAT_PADS, "connectfunc for %s:%s set to %s\n",
456 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (connect));
460 * gst_pad_set_getcaps_function:
461 * @pad: the pad to set the getcaps function for
462 * @getcaps: the getcaps function
464 * Set the given getcaps function for the pad.
467 gst_pad_set_getcaps_function (GstPad *pad,
468 GstPadGetCapsFunction getcaps)
470 g_return_if_fail (pad != NULL);
471 g_return_if_fail (GST_IS_REAL_PAD (pad));
473 GST_RPAD_GETCAPSFUNC (pad) = getcaps;
474 GST_DEBUG (GST_CAT_PADS, "getcapsfunc for %s:%s set to %s\n",
475 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (getcaps));
478 * gst_pad_set_bufferpool_function:
479 * @pad: the pad to set the bufferpool function for
480 * @bufpool: the bufferpool function
482 * Set the given bufferpool function for the pad.
485 gst_pad_set_bufferpool_function (GstPad *pad,
486 GstPadBufferPoolFunction bufpool)
488 g_return_if_fail (pad != NULL);
489 g_return_if_fail (GST_IS_REAL_PAD (pad));
491 GST_RPAD_BUFFERPOOLFUNC (pad) = bufpool;
492 GST_DEBUG (GST_CAT_PADS, "bufferpoolfunc for %s:%s set to %s\n",
493 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (bufpool));
497 gst_pad_push_func(GstPad *pad, GstBuffer *buf)
499 if (GST_RPAD_CHAINFUNC (GST_RPAD_PEER (pad)) != NULL) {
500 GST_DEBUG (GST_CAT_DATAFLOW, "calling chain function %s\n",
501 GST_DEBUG_FUNCPTR_NAME (GST_RPAD_CHAINFUNC (GST_RPAD_PEER (pad))));
502 (GST_RPAD_CHAINFUNC (GST_RPAD_PEER (pad))) (pad, buf);
504 GST_DEBUG (GST_CAT_DATAFLOW, "default pad_push handler in place, no chain function\n");
505 g_warning ("(internal error) default pad_push in place for pad %s:%s but it has no chain function",
506 GST_DEBUG_PAD_NAME (pad));
512 * gst_pad_disconnect:
513 * @srcpad: the source pad to disconnect
514 * @sinkpad: the sink pad to disconnect
516 * Disconnects the source pad from the sink pad.
519 gst_pad_disconnect (GstPad *srcpad,
522 GstRealPad *realsrc, *realsink;
525 g_return_if_fail (srcpad != NULL);
526 g_return_if_fail (GST_IS_PAD (srcpad));
527 g_return_if_fail (sinkpad != NULL);
528 g_return_if_fail (GST_IS_PAD (sinkpad));
530 GST_INFO (GST_CAT_ELEMENT_PADS, "disconnecting %s:%s(%p) and %s:%s(%p)",
531 GST_DEBUG_PAD_NAME (srcpad), srcpad, GST_DEBUG_PAD_NAME (sinkpad), sinkpad);
533 /* now we need to deal with the real/ghost stuff */
534 realsrc = GST_PAD_REALIZE (srcpad);
535 realsink = GST_PAD_REALIZE (sinkpad);
537 g_return_if_fail (GST_RPAD_PEER (realsrc) != NULL);
538 g_return_if_fail (GST_RPAD_PEER (realsink) != NULL);
540 if ((GST_RPAD_DIRECTION (realsrc) == GST_PAD_SINK) &&
541 (GST_RPAD_DIRECTION (realsink) == GST_PAD_SRC)) {
548 g_return_if_fail ((GST_RPAD_DIRECTION (realsrc) == GST_PAD_SRC) &&
549 (GST_RPAD_DIRECTION (realsink) == GST_PAD_SINK));
551 /* first clear peers */
552 GST_RPAD_PEER (realsrc) = NULL;
553 GST_RPAD_PEER (realsink) = NULL;
555 /* reset the filters, both filters are refcounted once */
556 if (GST_RPAD_FILTER (realsrc)) {
557 gst_caps_unref (GST_RPAD_FILTER (realsrc));
558 GST_RPAD_FILTER (realsink) = NULL;
559 GST_RPAD_FILTER (realsrc) = NULL;
562 /* now tell the scheduler */
563 if (GST_PAD_PARENT (realsrc)->sched)
564 gst_scheduler_pad_disconnect (GST_PAD_PARENT (realsrc)->sched, (GstPad *)realsrc, (GstPad *)realsink);
565 else if (GST_PAD_PARENT (realsink)->sched)
566 gst_scheduler_pad_disconnect (GST_PAD_PARENT (realsink)->sched, (GstPad *)realsrc, (GstPad *)realsink);
568 /* hold a reference, as they can go away in the signal handlers */
569 gst_object_ref (GST_OBJECT (realsrc));
570 gst_object_ref (GST_OBJECT (realsink));
572 /* fire off a signal to each of the pads telling them that they've been disconnected */
573 g_signal_emit (G_OBJECT (realsrc), gst_real_pad_signals[REAL_DISCONNECTED], 0, realsink);
574 g_signal_emit (G_OBJECT (realsink), gst_real_pad_signals[REAL_DISCONNECTED], 0, realsrc);
576 GST_INFO (GST_CAT_ELEMENT_PADS, "disconnected %s:%s and %s:%s",
577 GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
579 gst_object_unref (GST_OBJECT (realsrc));
580 gst_object_unref (GST_OBJECT (realsink));
584 * gst_pad_can_connect_filtered:
585 * @srcpad: the source pad to connect
586 * @sinkpad: the sink pad to connect
587 * @filtercaps: the filter caps.
589 * Checks if the source pad and the sink pad can be connected.
590 * The filter indicates the media type that should flow trought this connection.
592 * Returns: TRUE if the pad can be connected, FALSE otherwise
595 gst_pad_can_connect_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
597 gint num_decoupled = 0;
598 GstRealPad *realsrc, *realsink;
601 g_return_val_if_fail (srcpad != NULL, FALSE);
602 g_return_val_if_fail (GST_IS_PAD (srcpad), FALSE);
603 g_return_val_if_fail (sinkpad != NULL, FALSE);
604 g_return_val_if_fail (GST_IS_PAD (sinkpad), FALSE);
606 /* now we need to deal with the real/ghost stuff */
607 realsrc = GST_PAD_REALIZE (srcpad);
608 realsink = GST_PAD_REALIZE (sinkpad);
610 g_return_val_if_fail (GST_RPAD_PEER (realsrc) == NULL, FALSE);
611 g_return_val_if_fail (GST_RPAD_PEER (realsink) == NULL, FALSE);
612 g_return_val_if_fail (GST_PAD_PARENT (realsrc) != NULL, FALSE);
613 g_return_val_if_fail (GST_PAD_PARENT (realsink) != NULL, FALSE);
615 if (realsrc->sched && realsink->sched) {
616 if (GST_FLAG_IS_SET (GST_PAD_PARENT (realsrc), GST_ELEMENT_DECOUPLED))
618 if (GST_FLAG_IS_SET (GST_PAD_PARENT (realsink), GST_ELEMENT_DECOUPLED))
621 if (realsrc->sched != realsink->sched && num_decoupled != 1) {
622 g_warning ("connecting pads with different scheds requires exactly one decoupled element (queue)\n");
627 /* check if the directions are compatible */
628 if (!(((GST_RPAD_DIRECTION (realsrc) == GST_PAD_SINK) &&
629 (GST_RPAD_DIRECTION (realsink) == GST_PAD_SRC)) ||
630 ((GST_RPAD_DIRECTION (realsrc) == GST_PAD_SRC) &&
631 (GST_RPAD_DIRECTION (realsink) == GST_PAD_SINK))))
639 * gst_pad_can_connect:
640 * @srcpad: the source pad to connect
641 * @sinkpad: the sink pad to connect
643 * Checks if the source pad can be connected to the sink pad.
645 * Returns: TRUE if the pads can be connected, FALSE otherwise
648 gst_pad_can_connect (GstPad *srcpad, GstPad *sinkpad)
650 return gst_pad_can_connect_filtered (srcpad, sinkpad, NULL);
654 * gst_pad_connect_filtered:
655 * @srcpad: the source pad to connect
656 * @sinkpad: the sink pad to connect
657 * @filtercaps: the filter caps.
659 * Connects the source pad to the sink pad. The filter indicates the media type
660 * that should flow trought this connection.
662 * Returns: TRUE if the pad could be connected, FALSE otherwise
665 gst_pad_connect_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
667 GstRealPad *realsrc, *realsink;
668 gint num_decoupled = 0;
671 g_return_val_if_fail (srcpad != NULL, FALSE);
672 g_return_val_if_fail (GST_IS_PAD (srcpad), FALSE);
673 g_return_val_if_fail (sinkpad != NULL, FALSE);
674 g_return_val_if_fail (GST_IS_PAD (sinkpad), FALSE);
676 GST_INFO (GST_CAT_PADS, "connecting %s:%s and %s:%s",
677 GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
679 /* now we need to deal with the real/ghost stuff */
680 realsrc = GST_PAD_REALIZE (srcpad);
681 realsink = GST_PAD_REALIZE (sinkpad);
683 if ((GST_PAD (realsrc) != srcpad) || (GST_PAD (realsink) != sinkpad)) {
684 GST_INFO (GST_CAT_PADS, "*actually* connecting %s:%s and %s:%s",
685 GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
688 g_return_val_if_fail (GST_RPAD_PEER (realsrc) == NULL, FALSE);
689 g_return_val_if_fail (GST_RPAD_PEER (realsink) == NULL, FALSE);
690 g_return_val_if_fail (GST_PAD_PARENT (realsrc) != NULL, FALSE);
691 g_return_val_if_fail (GST_PAD_PARENT (realsink) != NULL, FALSE);
693 if (realsrc->sched && realsink->sched) {
694 if (GST_FLAG_IS_SET (GST_PAD_PARENT (realsrc), GST_ELEMENT_DECOUPLED))
696 if (GST_FLAG_IS_SET (GST_PAD_PARENT (realsink), GST_ELEMENT_DECOUPLED))
699 if (realsrc->sched != realsink->sched && num_decoupled != 1) {
700 g_warning ("connecting pads with different scheds requires exactly one decoupled element (queue)\n");
705 /* check for reversed directions and swap if necessary */
706 if ((GST_RPAD_DIRECTION (realsrc) == GST_PAD_SINK) &&
707 (GST_RPAD_DIRECTION (realsink) == GST_PAD_SRC)) {
714 g_return_val_if_fail ((GST_RPAD_DIRECTION (realsrc) == GST_PAD_SRC) &&
715 (GST_RPAD_DIRECTION (realsink) == GST_PAD_SINK), FALSE);
717 /* first set peers */
718 GST_RPAD_PEER (realsrc) = realsink;
719 GST_RPAD_PEER (realsink) = realsrc;
721 /* try to negotiate the pads, we don't need to clear the caps here */
722 if (!gst_pad_try_reconnect_filtered_func (realsrc, realsink, filtercaps, FALSE)) {
723 GST_DEBUG (GST_CAT_CAPS, "pads cannot connect\n");
725 GST_RPAD_PEER (realsrc) = NULL;
726 GST_RPAD_PEER (realsink) = NULL;
731 /* fire off a signal to each of the pads telling them that they've been connected */
732 g_signal_emit (G_OBJECT (realsrc), gst_real_pad_signals[REAL_CONNECTED], 0, realsink);
733 g_signal_emit (G_OBJECT (realsink), gst_real_pad_signals[REAL_CONNECTED], 0, realsrc);
735 /* now tell the scheduler(s) */
737 gst_scheduler_pad_connect (realsrc->sched, (GstPad *)realsrc, (GstPad *)realsink);
738 else if (realsink->sched)
739 gst_scheduler_pad_connect (realsink->sched, (GstPad *)realsrc, (GstPad *)realsink);
741 GST_INFO (GST_CAT_PADS, "connected %s:%s and %s:%s",
742 GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
749 * @srcpad: the source pad to connect
750 * @sinkpad: the sink pad to connect
752 * Connects the source pad to the sink pad.
754 * Returns: TRUE if the pad could be connected, FALSE otherwise
757 gst_pad_connect (GstPad *srcpad, GstPad *sinkpad)
759 return gst_pad_connect_filtered (srcpad, sinkpad, NULL);
763 * gst_pad_set_parent:
764 * @pad: the pad to set the parent
765 * @parent: the object to set the parent to
767 * Sets the parent object of a pad.
770 gst_pad_set_parent (GstPad *pad,
773 g_return_if_fail (pad != NULL);
774 g_return_if_fail (GST_IS_PAD (pad));
775 g_return_if_fail (GST_PAD_PARENT (pad) == NULL);
776 g_return_if_fail (parent != NULL);
777 g_return_if_fail (GST_IS_OBJECT (parent));
778 g_return_if_fail ((gpointer)pad != (gpointer)parent);
780 gst_object_set_parent (GST_OBJECT (pad), parent);
784 * gst_pad_get_parent:
785 * @pad: the pad to get the parent from
787 * Get the parent object of this pad.
789 * Returns: the parent object
792 gst_pad_get_parent (GstPad *pad)
794 g_return_val_if_fail (pad != NULL, NULL);
795 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
797 return GST_PAD_PARENT (pad);
801 * gst_pad_get_padtemplate:
802 * @pad: the pad to get the padtemplate from
804 * Get the padtemplate object of this pad.
806 * Returns: the padtemplate object
809 gst_pad_get_padtemplate (GstPad *pad)
811 g_return_val_if_fail (pad != NULL, NULL);
812 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
814 return GST_PAD_PADTEMPLATE (pad);
820 * @pad: the pad to set the scheduler for
821 * @sched: The scheduler to set
823 * Set the scheduler for the pad
826 gst_pad_set_sched (GstPad *pad, GstScheduler *sched)
828 g_return_if_fail (pad != NULL);
829 g_return_if_fail (GST_IS_PAD (pad));
831 GST_RPAD_SCHED(pad) = sched;
836 * @pad: the pad to get the scheduler from
838 * Get the scheduler of the pad
840 * Returns: the scheduler of the pad.
843 gst_pad_get_sched (GstPad *pad)
845 g_return_val_if_fail (pad != NULL, NULL);
846 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
848 return GST_RPAD_SCHED(pad);
852 * gst_pad_unset_sched:
853 * @pad: the pad to unset the scheduler for
855 * Unset the scheduler for the pad
858 gst_pad_unset_sched (GstPad *pad)
860 g_return_if_fail (pad != NULL);
861 g_return_if_fail (GST_IS_PAD (pad));
863 GST_RPAD_SCHED(pad) = NULL;
867 * gst_pad_get_real_parent:
868 * @pad: the pad to get the parent from
870 * Get the real parent object of this pad. If the pad
871 * is a ghostpad, the actual owner of the real pad is
872 * returned, as opposed to the gst_pad_get_parent().
874 * Returns: the parent object
877 gst_pad_get_real_parent (GstPad *pad)
879 g_return_val_if_fail (pad != NULL, NULL);
880 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
882 return GST_PAD_PARENT (GST_PAD (GST_PAD_REALIZE (pad)));
886 * gst_pad_add_ghost_pad:
887 * @pad: the pad to set the ghost parent
888 * @ghostpad: the ghost pad to add
890 * Add a ghost pad to a pad.
893 gst_pad_add_ghost_pad (GstPad *pad,
898 g_return_if_fail (pad != NULL);
899 g_return_if_fail (GST_IS_PAD (pad));
900 g_return_if_fail (ghostpad != NULL);
901 g_return_if_fail (GST_IS_GHOST_PAD (ghostpad));
903 realpad = GST_PAD_REALIZE (pad);
905 realpad->ghostpads = g_list_prepend (realpad->ghostpads, ghostpad);
910 * gst_pad_remove_ghost_pad:
911 * @pad: the pad to remove the ghost parent
912 * @ghostpad: the ghost pad to remove from the pad
914 * Remove a ghost pad from a pad.
917 gst_pad_remove_ghost_pad (GstPad *pad,
922 g_return_if_fail (pad != NULL);
923 g_return_if_fail (GST_IS_PAD (pad));
924 g_return_if_fail (ghostpad != NULL);
925 g_return_if_fail (GST_IS_GHOST_PAD (ghostpad));
927 realpad = GST_PAD_REALIZE (pad);
929 realpad->ghostpads = g_list_remove (realpad->ghostpads, ghostpad);
933 * gst_pad_get_ghost_pad_list:
934 * @pad: the pad to get the ghost parents from
936 * Get the ghost parents of this pad.
938 * Returns: a GList of ghost pads
941 gst_pad_get_ghost_pad_list (GstPad *pad)
943 g_return_val_if_fail (pad != NULL, NULL);
944 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
946 return GST_PAD_REALIZE(pad)->ghostpads;
949 /* an internal caps negotiation helper function does:
951 * 1. optinally calls the pad connect function with the provided caps
952 * 2. deal with the result code of the connect function
953 * 3. set fixed caps on the pad.
955 static GstPadConnectReturn
956 gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
959 GstElement *parent = GST_PAD_PARENT (pad);
961 /* thomas: FIXME: is this the right result to return ? */
962 g_return_val_if_fail (pad != NULL, GST_PAD_CONNECT_REFUSED);
963 g_return_val_if_fail (GST_IS_PAD (pad), GST_PAD_CONNECT_REFUSED);
965 /* if this pad has a parent and the parent is not READY, delay the
967 if (parent && GST_STATE (parent) < GST_STATE_READY)
969 GST_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not ready\n",
970 GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (pad));
971 return GST_PAD_CONNECT_DELAYED;
974 GST_INFO (GST_CAT_CAPS, "trying to set caps %p on pad %s:%s",
975 caps, GST_DEBUG_PAD_NAME (pad));
977 /* we need to notify the connect function */
978 if (notify && GST_RPAD_CONNECTFUNC (pad)) {
979 GstPadConnectReturn res;
982 GST_INFO (GST_CAT_CAPS, "calling connect function on pad %s:%s",
983 GST_DEBUG_PAD_NAME (pad));
985 /* call the connect function */
986 res = GST_RPAD_CONNECTFUNC (pad) (GST_PAD (pad), caps);
989 case GST_PAD_CONNECT_REFUSED:
990 debug_string = "REFUSED";
992 case GST_PAD_CONNECT_OK:
995 case GST_PAD_CONNECT_DONE:
996 debug_string = "DONE";
998 case GST_PAD_CONNECT_DELAYED:
999 debug_string = "DELAYED";
1002 g_warning ("unknown return code from connect function of pad %s:%s",
1003 GST_DEBUG_PAD_NAME (pad));
1004 return GST_PAD_CONNECT_REFUSED;
1007 GST_INFO (GST_CAT_CAPS, "got reply %s (%d) from connect function on pad %s:%s",
1008 debug_string, res, GST_DEBUG_PAD_NAME (pad));
1010 /* done means the connect function called another caps negotiate function
1011 * on this pad that succeeded, we dont need to continue */
1012 if (res == GST_PAD_CONNECT_DONE) {
1013 GST_INFO (GST_CAT_CAPS, "pad %s:%s is done", GST_DEBUG_PAD_NAME (pad));
1014 return GST_PAD_CONNECT_DONE;
1016 if (res == GST_PAD_CONNECT_REFUSED) {
1017 GST_INFO (GST_CAT_CAPS, "pad %s:%s doesn't accept caps",
1018 GST_DEBUG_PAD_NAME (pad));
1019 return GST_PAD_CONNECT_REFUSED;
1022 /* we can only set caps on the pad if they are fixed */
1023 if (GST_CAPS_IS_FIXED (caps)) {
1025 GST_INFO (GST_CAT_CAPS, "setting caps on pad %s:%s",
1026 GST_DEBUG_PAD_NAME (pad));
1027 /* if we got this far all is ok, remove the old caps, set the new one */
1028 oldcaps = GST_PAD_CAPS (pad);
1029 if (caps) gst_caps_ref (caps);
1030 GST_PAD_CAPS (pad) = caps;
1031 if (oldcaps) gst_caps_unref (oldcaps);
1034 GST_INFO (GST_CAT_CAPS, "caps are not fixed on pad %s:%s, not setting them yet",
1035 GST_DEBUG_PAD_NAME (pad));
1038 return GST_PAD_CONNECT_OK;
1042 * gst_pad_try_set_caps:
1043 * @pad: the pad to try to set the caps on
1044 * @caps: the caps to set
1046 * Try to set the caps on the given pad.
1048 * Returns: TRUE if the caps could be set
1051 gst_pad_try_set_caps (GstPad *pad, GstCaps *caps)
1053 GstRealPad *peer, *realpad;
1055 realpad = GST_PAD_REALIZE (pad);
1056 peer = GST_RPAD_PEER (realpad);
1058 GST_INFO (GST_CAT_CAPS, "trying to set caps %p on pad %s:%s",
1059 caps, GST_DEBUG_PAD_NAME (realpad));
1061 /* setting non fixed caps on a pad is not allowed */
1062 if (!GST_CAPS_IS_FIXED (caps)) {
1063 GST_INFO (GST_CAT_CAPS, "trying to set unfixed caps on pad %s:%s, not allowed",
1064 GST_DEBUG_PAD_NAME (realpad));
1065 g_warning ("trying to set non fixed caps on pad %s:%s, not allowed",
1066 GST_DEBUG_PAD_NAME (realpad));
1067 gst_caps_debug (caps);
1070 /* if we have a peer try to set the caps, notifying the peerpad
1071 * if it has a connect function */
1072 if (peer && (gst_pad_try_set_caps_func (peer, caps, TRUE) != GST_PAD_CONNECT_OK))
1074 GST_INFO (GST_CAT_CAPS, "tried to set caps on peerpad %s:%s but couldn't",
1075 GST_DEBUG_PAD_NAME (peer));
1078 /* then try to set our own caps, we don't need to be notified */
1079 if (gst_pad_try_set_caps_func (realpad, caps, FALSE) != GST_PAD_CONNECT_OK)
1081 GST_INFO (GST_CAT_CAPS, "tried to set own caps on pad %s:%s but couldn't",
1082 GST_DEBUG_PAD_NAME (realpad));
1085 GST_INFO (GST_CAT_CAPS, "succeeded setting caps %p on pad %s:%s",
1086 caps, GST_DEBUG_PAD_NAME (realpad));
1087 gst_caps_debug (caps);
1088 g_assert (GST_PAD_CAPS (pad));
1093 /* this is a caps negotiation convenience routine, it performs:
1095 * 1. optionally clear any pad caps
1096 * 2. calculate the intersection between the two pad tamplate/getcaps caps
1097 * 3. calculate the intersection with the (optional) filtercaps.
1098 * 4. store the intersection in the pad filter
1099 * 5. store the app filtercaps in the pad appfilter.
1100 * 6. start the caps negotiation.
1103 gst_pad_try_reconnect_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad, GstCaps *filtercaps, gboolean clear)
1105 GstCaps *srccaps, *sinkcaps;
1106 GstCaps *intersection = NULL;
1107 GstRealPad *realsrc, *realsink;
1109 realsrc = GST_PAD_REALIZE (srcpad);
1110 realsink = GST_PAD_REALIZE (sinkpad);
1112 g_return_val_if_fail (GST_RPAD_PEER (realsrc) != NULL, FALSE);
1113 g_return_val_if_fail (GST_RPAD_PEER (realsink) == realsrc, FALSE);
1115 /* optinally clear the caps */
1117 GST_INFO (GST_CAT_PADS, "reconnect filtered %s:%s and %s:%s, clearing caps",
1118 GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
1120 GST_PAD_CAPS (GST_PAD (realsrc)) = NULL;
1121 GST_PAD_CAPS (GST_PAD (realsink)) = NULL;
1124 GST_INFO (GST_CAT_PADS, "reconnect filtered %s:%s and %s:%s",
1125 GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
1128 srccaps = gst_pad_get_caps (GST_PAD (realsrc));
1129 GST_INFO (GST_CAT_PADS, "dumping caps of pad %s:%s", GST_DEBUG_PAD_NAME (realsrc));
1130 gst_caps_debug (srccaps);
1131 sinkcaps = gst_pad_get_caps (GST_PAD (realsink));
1132 GST_INFO (GST_CAT_PADS, "dumping caps of pad %s:%s", GST_DEBUG_PAD_NAME (realsink));
1133 gst_caps_debug (sinkcaps);
1135 /* first take the intersection of the pad caps */
1136 intersection = gst_caps_intersect (srccaps, sinkcaps);
1138 /* if we have no intersection but one of the caps was not NULL.. */
1139 if (!intersection && (srccaps || sinkcaps )) {
1140 /* the intersection is NULL but the pad caps were not both NULL,
1141 * this means they have no common format */
1142 GST_INFO (GST_CAT_PADS, "pads %s:%s and %s:%s have no common type",
1143 GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
1147 GST_INFO (GST_CAT_PADS, "pads %s:%s and %s:%s intersected to %s caps",
1148 GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink),
1149 ((intersection && GST_CAPS_IS_FIXED (intersection)) ? "fixed" : "variable"));
1151 /* then filter this against the app filter */
1153 GstCaps *filtered_intersection = gst_caps_intersect (intersection, filtercaps);
1155 /* get rid of the old intersection here */
1156 gst_caps_unref (intersection);
1158 if (!filtered_intersection) {
1159 GST_INFO (GST_CAT_PADS, "filtered connection between pads %s:%s and %s:%s is empty",
1160 GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
1163 intersection = filtered_intersection;
1165 /* keep a reference to the app caps */
1166 GST_RPAD_APPFILTER (realsink) = filtercaps;
1167 GST_RPAD_APPFILTER (realsrc) = filtercaps;
1170 GST_DEBUG (GST_CAT_CAPS, "setting filter for connection to:\n");
1171 gst_caps_debug (intersection);
1173 GST_RPAD_FILTER (realsrc) = intersection;
1174 GST_RPAD_FILTER (realsink) = intersection;
1176 return gst_pad_perform_negotiate (GST_PAD (realsrc), GST_PAD (realsink));
1180 * gst_pad_perform_negotiate:
1182 * @sinkpad: a sinkpad
1184 * Try to negotiate the pads.
1186 * Returns: a boolean indicating the pad succesfully negotiated.
1189 gst_pad_perform_negotiate (GstPad *srcpad, GstPad *sinkpad)
1191 GstCaps *intersection;
1192 GstRealPad *realsrc, *realsink;
1193 GstCaps *srccaps, *sinkcaps;
1195 g_return_val_if_fail (srcpad != NULL, FALSE);
1196 g_return_val_if_fail (sinkpad != NULL, FALSE);
1198 realsrc = GST_PAD_REALIZE (srcpad);
1199 realsink = GST_PAD_REALIZE (sinkpad);
1201 g_return_val_if_fail (GST_RPAD_PEER (realsrc) != NULL, FALSE);
1202 g_return_val_if_fail (GST_RPAD_PEER (realsink) == realsrc, FALSE);
1204 /* calculate the new caps here */
1205 srccaps = gst_pad_get_caps (GST_PAD (realsrc));
1206 GST_INFO (GST_CAT_PADS, "dumping caps of pad %s:%s", GST_DEBUG_PAD_NAME (realsrc));
1207 gst_caps_debug (srccaps);
1208 sinkcaps = gst_pad_get_caps (GST_PAD (realsink));
1209 GST_INFO (GST_CAT_PADS, "dumping caps of pad %s:%s", GST_DEBUG_PAD_NAME (realsink));
1210 gst_caps_debug (sinkcaps);
1211 intersection = gst_caps_intersect (srccaps, sinkcaps);
1213 /* no negotiation is performed it the pads have filtercaps */
1215 GstPadConnectReturn res;
1217 res = gst_pad_try_set_caps_func (realsrc, intersection, TRUE);
1218 if (res == GST_PAD_CONNECT_REFUSED)
1220 if (res == GST_PAD_CONNECT_DONE)
1223 res = gst_pad_try_set_caps_func (realsink, intersection, TRUE);
1224 if (res == GST_PAD_CONNECT_REFUSED)
1226 if (res == GST_PAD_CONNECT_DONE)
1233 * gst_pad_try_reconnect_filtered:
1234 * @pad: the pad to reconnect
1235 * @caps: the capabilities to use in the reconnectiong
1237 * Try to reconnect this pad and its peer with the specified caps
1239 * Returns: a boolean indicating the peer pad could accept the caps.
1242 gst_pad_try_reconnect_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
1244 GstRealPad *realsrc, *realsink;
1246 g_return_val_if_fail (srcpad != NULL, FALSE);
1247 g_return_val_if_fail (sinkpad != NULL, FALSE);
1249 realsrc = GST_PAD_REALIZE (srcpad);
1250 realsink = GST_PAD_REALIZE (sinkpad);
1252 g_return_val_if_fail (GST_RPAD_PEER (realsrc) != NULL, FALSE);
1253 g_return_val_if_fail (GST_RPAD_PEER (realsink) == realsrc, FALSE);
1255 return gst_pad_try_reconnect_filtered_func (realsrc, realsink, filtercaps, TRUE);
1259 * gst_pad_reconnect_filtered:
1260 * @pad: the pad to reconnect
1261 * @caps: the capabilities to use in the reconnectiong
1263 * Try to reconnect this pad and its peer with the specified caps.
1265 * Returns: a boolean indicating the peer pad could accept the caps.
1266 * if FALSE is returned, the pads are disconnected.
1269 gst_pad_reconnect_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
1271 GstRealPad *realsrc, *realsink;
1273 g_return_val_if_fail (srcpad != NULL, FALSE);
1274 g_return_val_if_fail (sinkpad != NULL, FALSE);
1276 realsrc = GST_PAD_REALIZE (srcpad);
1277 realsink = GST_PAD_REALIZE (sinkpad);
1279 g_return_val_if_fail (GST_RPAD_PEER (realsrc) != NULL, FALSE);
1280 g_return_val_if_fail (GST_RPAD_PEER (realsink) == realsrc, FALSE);
1282 if (!gst_pad_try_reconnect_filtered_func (realsrc, realsink, filtercaps, TRUE)) {
1283 gst_pad_disconnect (srcpad, GST_PAD (GST_PAD_PEER (srcpad)));
1290 * gst_pad_proxy_connect:
1291 * @pad: the pad to proxy to
1292 * @caps: the capabilities to use in the proxying
1294 * Proxy the connect function to the specified pad.
1296 * Returns: a boolean indicating the peer pad could accept the caps.
1299 gst_pad_proxy_connect (GstPad *pad, GstCaps *caps)
1301 GstRealPad *peer, *realpad;
1303 realpad = GST_PAD_REALIZE (pad);
1305 peer = GST_RPAD_PEER (realpad);
1307 GST_INFO (GST_CAT_CAPS, "proxy connect to pad %s:%s",
1308 GST_DEBUG_PAD_NAME (realpad));
1310 if (peer && !gst_pad_try_set_caps_func (peer, caps, TRUE))
1311 return GST_PAD_CONNECT_REFUSED;
1312 if (!gst_pad_try_set_caps_func (realpad, caps, FALSE))
1313 return GST_PAD_CONNECT_REFUSED;
1315 return GST_PAD_CONNECT_OK;
1320 * @pad: the pad to get the capabilities from
1322 * Get the capabilities of this pad.
1324 * Returns: the capabilities of this pad
1327 gst_pad_get_caps (GstPad *pad)
1329 GstRealPad *realpad;
1331 g_return_val_if_fail (pad != NULL, NULL);
1332 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
1334 realpad = GST_PAD_REALIZE (pad);
1336 GST_DEBUG (GST_CAT_CAPS, "get pad caps of %s:%s (%p)\n",
1337 GST_DEBUG_PAD_NAME (realpad), realpad);
1339 if (GST_PAD_CAPS (realpad)) {
1340 GST_DEBUG (GST_CAT_CAPS, "using pad real caps\n");
1341 return GST_PAD_CAPS (realpad);
1343 else if GST_RPAD_GETCAPSFUNC (realpad) {
1344 GST_DEBUG (GST_CAT_CAPS, "using pad get function\n");
1345 return GST_RPAD_GETCAPSFUNC (realpad) (GST_PAD_CAST (realpad), NULL);
1347 else if (GST_PAD_PADTEMPLATE (realpad)) {
1348 GST_DEBUG (GST_CAT_CAPS, "using pad template\n");
1349 return GST_PADTEMPLATE_CAPS (GST_PAD_PADTEMPLATE (realpad));
1351 GST_DEBUG (GST_CAT_CAPS, "pad has no caps\n");
1357 * gst_pad_get_padtemplate_caps:
1358 * @pad: the pad to get the capabilities from
1360 * Get the capabilities of this pad.
1362 * Returns: a list of the capabilities of this pad
1365 gst_pad_get_padtemplate_caps (GstPad *pad)
1367 g_return_val_if_fail (pad != NULL, NULL);
1368 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
1370 if (GST_PAD_PADTEMPLATE (pad))
1371 return GST_PADTEMPLATE_CAPS (GST_PAD_PADTEMPLATE (pad));
1378 * gst_padtemplate_get_caps_by_name:
1379 * @templ: the padtemplate to get the capabilities from
1380 * @name: the name of the capability to get
1382 * Get the capability with the given name from this padtemplate.
1384 * Returns: a capability or NULL if not found
1387 gst_padtemplate_get_caps_by_name (GstPadTemplate *templ, const gchar *name)
1391 g_return_val_if_fail (templ != NULL, NULL);
1393 caps = GST_PADTEMPLATE_CAPS (templ);
1397 return gst_caps_get_by_name (caps, name);
1401 * gst_pad_check_compatibility:
1402 * @srcpad: the srcpad to check
1403 * @sinkpad: the sinkpad to check against
1405 * Check if two pads have compatible capabilities.
1407 * Returns: TRUE if they are compatible or the capabilities
1408 * could not be checked
1411 gst_pad_check_compatibility (GstPad *srcpad, GstPad *sinkpad)
1413 g_return_val_if_fail (srcpad != NULL, FALSE);
1414 g_return_val_if_fail (GST_IS_PAD (srcpad), FALSE);
1415 g_return_val_if_fail (sinkpad != NULL, FALSE);
1416 g_return_val_if_fail (GST_IS_PAD (sinkpad), FALSE);
1418 if (GST_PAD_CAPS (srcpad) && GST_PAD_CAPS (sinkpad)) {
1419 if (!gst_caps_check_compatibility (GST_PAD_CAPS (srcpad), GST_PAD_CAPS (sinkpad))) {
1427 GST_DEBUG (GST_CAT_PADS, "could not check capabilities of pads (%s:%s) and (%s:%s) %p %p\n",
1428 GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad),
1429 GST_PAD_CAPS (srcpad), GST_PAD_CAPS (sinkpad));
1436 * @pad: the pad to get the peer from
1438 * Get the peer pad of this pad.
1440 * Returns: the peer pad
1443 gst_pad_get_peer (GstPad *pad)
1445 g_return_val_if_fail (pad != NULL, NULL);
1446 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
1448 return GST_PAD (GST_PAD_PEER (pad));
1452 * gst_pad_get_allowed_caps:
1453 * @pad: the pad to get the allowed caps from
1455 * Gst the caps of the allowed media types that can
1456 * go through this pad.
1458 * Returns: the allowed caps
1461 gst_pad_get_allowed_caps (GstPad *pad)
1463 g_return_val_if_fail (pad != NULL, NULL);
1464 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
1466 GST_DEBUG (GST_CAT_PROPERTIES, "get allowed caps of %s:%s\n", GST_DEBUG_PAD_NAME (pad));
1468 return gst_caps_copy (GST_RPAD_FILTER (pad));
1472 * gst_pad_get_allowed_caps:
1473 * @pad: the pad to get the allowed caps from
1475 * Gst the caps of the allowed media types that can
1476 * go through this pad.
1478 * Returns: the allowed caps
1481 gst_pad_recalc_allowed_caps (GstPad *pad)
1485 g_return_val_if_fail (pad != NULL, FALSE);
1486 g_return_val_if_fail (GST_IS_PAD (pad), FALSE);
1488 GST_DEBUG (GST_CAT_PROPERTIES, "set allowed caps of %s:%s\n", GST_DEBUG_PAD_NAME (pad));
1490 peer = GST_RPAD_PEER (pad);
1492 return gst_pad_try_reconnect_filtered (pad, GST_PAD (peer), GST_RPAD_APPFILTER (pad));
1498 * gst_pad_get_bufferpool:
1499 * @pad: the pad to get the bufferpool from
1501 * Get the bufferpool of the peer pad of the given
1504 * Returns: The GstBufferPool or NULL.
1507 gst_pad_get_bufferpool (GstPad *pad)
1511 g_return_val_if_fail (pad != NULL, NULL);
1512 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
1514 peer = GST_RPAD_PEER (pad);
1519 GST_DEBUG_ENTER ("(%s:%s)", GST_DEBUG_PAD_NAME (pad));
1521 if (peer->bufferpoolfunc) {
1522 GST_DEBUG (GST_CAT_PADS, "calling bufferpoolfunc &%s (@%p) of peer pad %s:%s\n",
1523 GST_DEBUG_FUNCPTR_NAME (peer->bufferpoolfunc), &peer->bufferpoolfunc, GST_DEBUG_PAD_NAME (((GstPad*) peer)));
1524 return (peer->bufferpoolfunc) (((GstPad*) peer));
1526 GST_DEBUG (GST_CAT_PADS, "no bufferpoolfunc for peer pad %s:%s at %p\n",
1527 GST_DEBUG_PAD_NAME (((GstPad*) peer)), &peer->bufferpoolfunc);
1533 gst_real_pad_dispose (GObject *object)
1535 GstPad *pad = GST_PAD (object);
1537 /* No connected pad can ever be disposed.
1538 * It has to have a parent to be connected and a parent would hold a reference */
1539 g_assert (GST_PAD_PEER (pad) == NULL);
1541 GST_DEBUG (GST_CAT_REFCOUNTING, "dispose %s:%s\n", GST_DEBUG_PAD_NAME(pad));
1543 if (GST_PAD_PADTEMPLATE (pad)){
1544 GST_DEBUG (GST_CAT_REFCOUNTING, "unreffing padtemplate'%s'\n", GST_OBJECT_NAME (GST_PAD_PADTEMPLATE (pad)));
1545 gst_object_unref (GST_OBJECT (GST_PAD_PADTEMPLATE (pad)));
1546 GST_PAD_PADTEMPLATE (pad) = NULL;
1549 /* we destroy the ghostpads, because they are nothing without the real pad */
1550 if (GST_REAL_PAD (pad)->ghostpads) {
1551 GList *orig, *ghostpads;
1553 orig = ghostpads = g_list_copy (GST_REAL_PAD (pad)->ghostpads);
1556 GstPad *ghostpad = GST_PAD (ghostpads->data);
1558 if (GST_IS_ELEMENT (GST_OBJECT_PARENT (ghostpad))){
1559 GST_DEBUG (GST_CAT_REFCOUNTING, "removing ghost pad from element '%s'\n",
1560 GST_OBJECT_NAME (GST_OBJECT_PARENT (ghostpad)));
1562 gst_element_remove_ghost_pad (GST_ELEMENT (GST_OBJECT_PARENT (ghostpad)), GST_PAD (ghostpad));
1564 ghostpads = g_list_next (ghostpads);
1567 g_list_free (GST_REAL_PAD(pad)->ghostpads);
1570 if (GST_IS_ELEMENT (GST_OBJECT_PARENT (pad))){
1571 GST_DEBUG (GST_CAT_REFCOUNTING, "removing pad from element '%s'\n",
1572 GST_OBJECT_NAME (GST_OBJECT (GST_ELEMENT (GST_OBJECT_PARENT (pad)))));
1574 gst_element_remove_pad (GST_ELEMENT (GST_OBJECT_PARENT (pad)), pad);
1577 G_OBJECT_CLASS (real_pad_parent_class)->dispose (object);
1581 #ifndef GST_DISABLE_LOADSAVE
1583 * gst_pad_load_and_connect:
1584 * @self: the XML node to read the description from
1585 * @parent: the element that has the pad
1587 * Read the pad definition from the XML node and connect the given pad
1588 * in element to a pad of an element up in the hierarchy.
1591 gst_pad_load_and_connect (xmlNodePtr self,
1594 xmlNodePtr field = self->xmlChildrenNode;
1595 GstPad *pad = NULL, *targetpad;
1596 guchar *peer = NULL;
1599 GstObject *grandparent;
1602 if (!strcmp (field->name, "name")) {
1603 pad = gst_element_get_pad (GST_ELEMENT (parent), xmlNodeGetContent (field));
1605 else if (!strcmp(field->name, "peer")) {
1606 peer = xmlNodeGetContent (field);
1608 field = field->next;
1610 g_return_if_fail (pad != NULL);
1612 if (peer == NULL) return;
1614 split = g_strsplit (peer, ".", 2);
1616 g_return_if_fail (split[0] != NULL);
1617 g_return_if_fail (split[1] != NULL);
1619 grandparent = gst_object_get_parent (parent);
1621 if (grandparent && GST_IS_BIN (grandparent)) {
1622 target = gst_bin_get_by_name_recurse_up (GST_BIN (grandparent), split[0]);
1627 if (target == NULL) goto cleanup;
1629 targetpad = gst_element_get_pad (target, split[1]);
1631 if (targetpad == NULL) goto cleanup;
1633 gst_pad_connect (pad, targetpad);
1640 * gst_pad_save_thyself:
1641 * @pad: the pad to save
1642 * @parent: the parent XML node to save the description in
1644 * Saves the pad into an xml representation
1646 * Returns: the xml representation of the pad
1649 gst_pad_save_thyself (GstObject *object,
1652 GstRealPad *realpad;
1655 g_return_val_if_fail (GST_IS_REAL_PAD (object), NULL);
1657 realpad = GST_REAL_PAD(object);
1659 xmlNewChild(parent,NULL,"name", GST_PAD_NAME (realpad));
1660 if (GST_RPAD_PEER(realpad) != NULL) {
1661 peer = GST_PAD(GST_RPAD_PEER(realpad));
1662 /* first check to see if the peer's parent's parent is the same */
1663 /* we just save it off */
1664 xmlNewChild(parent,NULL,"peer",g_strdup_printf("%s.%s",
1665 GST_OBJECT_NAME (GST_PAD_PARENT (peer)), GST_PAD_NAME (peer)));
1667 xmlNewChild(parent,NULL,"peer","");
1673 * gst_pad_ghost_save_thyself:
1674 * @pad: the pad to save
1676 * @parent: the parent XML node to save the description in
1678 * Saves the ghost pad into an xml representation.
1680 * Returns: the xml representation of the pad
1683 gst_pad_ghost_save_thyself (GstPad *pad,
1689 g_return_val_if_fail (GST_IS_GHOST_PAD (pad), NULL);
1691 self = xmlNewChild (parent, NULL, "ghostpad", NULL);
1692 xmlNewChild (self, NULL, "name", GST_PAD_NAME (pad));
1693 xmlNewChild (self, NULL, "parent", GST_OBJECT_NAME (GST_PAD_PARENT (pad)));
1695 /* FIXME FIXME FIXME! */
1699 #endif /* GST_DISABLE_LOADSAVE */
1701 #ifndef gst_pad_push
1704 * @pad: the pad to push
1705 * @buf: the buffer to push
1707 * Push a buffer to the peer of the pad.
1710 gst_pad_push (GstPad *pad, GstBuffer *buf)
1712 GstRealPad *peer = GST_RPAD_PEER (pad);
1714 GST_DEBUG_ENTER ("(%s:%s)", GST_DEBUG_PAD_NAME (pad));
1716 g_return_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SRC);
1719 g_warning ("push on pad %s:%s but it is unconnected", GST_DEBUG_PAD_NAME (pad));
1722 if (peer->chainhandler) {
1724 GST_DEBUG (GST_CAT_DATAFLOW, "calling chainhandler &%s of peer pad %s:%s\n",
1725 GST_DEBUG_FUNCPTR_NAME (peer->chainhandler), GST_DEBUG_PAD_NAME (GST_PAD (peer)));
1726 (peer->chainhandler) (GST_PAD_CAST (peer), buf);
1730 g_warning ("trying to push a NULL buffer on pad %s:%s", GST_DEBUG_PAD_NAME (peer));
1735 g_warning ("(internal error) push on pad %s:%s but it has no chainhandler", GST_DEBUG_PAD_NAME (peer));
1738 /* clean up the mess here */
1740 if (GST_IS_BUFFER (buf))
1741 gst_buffer_unref (buf);
1743 gst_event_free (GST_EVENT (buf));
1748 #ifndef gst_pad_pull
1751 * @pad: the pad to pull
1753 * Pull a buffer from the peer pad.
1755 * Returns: a new buffer from the peer pad.
1758 gst_pad_pull (GstPad *pad)
1760 GstRealPad *peer = GST_RPAD_PEER(pad);
1762 GST_DEBUG_ENTER("(%s:%s)",GST_DEBUG_PAD_NAME(pad));
1764 g_return_val_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SINK, NULL);
1767 gst_element_error (GST_PAD_PARENT (pad),
1768 "pull on pad %s:%s but it was unconnected",
1769 GST_ELEMENT_NAME (GST_PAD_PARENT (pad)), GST_PAD_NAME (pad),
1773 if (peer->gethandler) {
1776 GST_DEBUG (GST_CAT_DATAFLOW, "calling gethandler %s of peer pad %s:%s\n",
1777 GST_DEBUG_FUNCPTR_NAME (peer->gethandler), GST_DEBUG_PAD_NAME (peer));
1779 buf = (peer->gethandler) (GST_PAD_CAST (peer));
1782 /* no null buffers allowed */
1783 gst_element_error (GST_PAD_PARENT (pad),
1784 "NULL buffer during pull on %s:%s", GST_DEBUG_PAD_NAME (pad), NULL);
1787 gst_element_error (GST_PAD_PARENT (pad),
1788 "(internal error) pull on pad %s:%s but the peer pad %s:%s has no gethandler",
1789 GST_DEBUG_PAD_NAME (pad), GST_DEBUG_PAD_NAME (peer),
1797 #ifndef gst_pad_pullregion
1799 * gst_pad_pullregion:
1800 * @pad: the pad to pull the region from
1801 * @type: the regiontype
1802 * @offset: the offset/start of the buffer to pull
1803 * @len: the length of the buffer to pull
1805 * Pull a buffer region from the peer pad. The region to pull can be
1806 * specified with a offset/lenght pair or with a start/legnth time
1807 * indicator as specified by the type parameter.
1809 * Returns: a new buffer from the peer pad with data in the specified
1813 gst_pad_pullregion (GstPad *pad, GstRegionType type, guint64 offset, guint64 len)
1816 GstBuffer *result = NULL;
1818 g_return_val_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SINK, NULL);
1821 peer = GST_RPAD_PEER(pad);
1822 g_return_val_if_fail (peer != NULL, NULL);
1825 gst_buffer_unref (result);
1827 GST_DEBUG_ENTER("(%s:%s,%d,%lld,%lld)",GST_DEBUG_PAD_NAME(pad),type,offset,len);
1829 if (peer->pullregionfunc) {
1830 GST_DEBUG (GST_CAT_DATAFLOW, "calling pullregionfunc &%s of peer pad %s:%s\n",
1831 GST_DEBUG_FUNCPTR_NAME (peer->pullregionfunc), GST_DEBUG_PAD_NAME(GST_PAD_CAST (peer)));
1832 result = (peer->pullregionfunc) (GST_PAD_CAST (peer), type, offset, len);
1834 GST_DEBUG (GST_CAT_DATAFLOW,"no pullregionfunc\n");
1840 while (result && !(GST_BUFFER_OFFSET (result) == offset &&
1841 GST_BUFFER_SIZE (result) == len));
1849 * @pad: the pad to peek
1851 * Peek for a buffer from the peer pad.
1853 * Returns: a from the peer pad or NULL if the peer has no buffer.
1856 gst_pad_peek (GstPad *pad)
1858 g_return_val_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SINK, NULL);
1860 return GST_RPAD_BUFPEN (GST_RPAD_PEER (pad));
1865 * @padlist: A list of pads
1867 * Wait for a buffer on the list of pads.
1869 * Returns: The pad that has a buffer available, use
1870 * #gst_pad_pull to get the buffer.
1873 gst_pad_select (GList *padlist)
1877 pad = gst_scheduler_pad_select (GST_PAD_PARENT (padlist->data)->sched, padlist);
1884 * @pad: The first pad to perform the select on
1887 * Wait for a buffer on the given of pads.
1889 * Returns: The pad that has a buffer available, use
1890 * #gst_pad_pull to get the buffer.
1893 gst_pad_selectv (GstPad *pad, ...)
1896 GList *padlist = NULL;
1902 va_start (var_args, pad);
1905 padlist = g_list_prepend (padlist, pad);
1906 pad = va_arg (var_args, GstPad *);
1908 result = gst_pad_select (padlist);
1909 g_list_free (padlist);
1916 /************************************************************************
1921 static void gst_padtemplate_class_init (GstPadTemplateClass *klass);
1922 static void gst_padtemplate_init (GstPadTemplate *templ);
1930 static GstObject *padtemplate_parent_class = NULL;
1931 static guint gst_padtemplate_signals[TEMPL_LAST_SIGNAL] = { 0 };
1934 gst_padtemplate_get_type (void)
1936 static GType padtemplate_type = 0;
1938 if (!padtemplate_type) {
1939 static const GTypeInfo padtemplate_info = {
1940 sizeof(GstPadTemplateClass),
1943 (GClassInitFunc)gst_padtemplate_class_init,
1946 sizeof(GstPadTemplate),
1948 (GInstanceInitFunc)gst_padtemplate_init,
1951 padtemplate_type = g_type_register_static(GST_TYPE_OBJECT, "GstPadTemplate", &padtemplate_info, 0);
1953 return padtemplate_type;
1957 gst_padtemplate_class_init (GstPadTemplateClass *klass)
1959 GObjectClass *gobject_class;
1960 GstObjectClass *gstobject_class;
1962 gobject_class = (GObjectClass*)klass;
1963 gstobject_class = (GstObjectClass*)klass;
1965 padtemplate_parent_class = g_type_class_ref(GST_TYPE_OBJECT);
1967 gst_padtemplate_signals[TEMPL_PAD_CREATED] =
1968 g_signal_new ("pad_created", G_TYPE_FROM_CLASS(klass), G_SIGNAL_RUN_LAST,
1969 G_STRUCT_OFFSET (GstPadTemplateClass, pad_created), NULL, NULL,
1970 gst_marshal_VOID__POINTER, G_TYPE_NONE, 1,
1974 gstobject_class->path_string_separator = "*";
1978 gst_padtemplate_init (GstPadTemplate *templ)
1983 * gst_padtemplate_new:
1984 * @name_template: the name template
1985 * @direction: the direction for the template
1986 * @presence: the presence of the pad
1987 * @caps: a list of capabilities for the template
1988 * @...: more capabilities
1990 * Creates a new padtemplate from the given arguments.
1992 * Returns: the new padtemplate
1995 gst_padtemplate_new (gchar *name_template,
1996 GstPadDirection direction, GstPadPresence presence,
1999 GstPadTemplate *new;
2001 GstCaps *thecaps = NULL;
2003 g_return_val_if_fail (name_template != NULL, NULL);
2005 new = g_object_new(gst_padtemplate_get_type () ,NULL);
2007 GST_PADTEMPLATE_NAME_TEMPLATE (new) = name_template;
2008 GST_PADTEMPLATE_DIRECTION (new) = direction;
2009 GST_PADTEMPLATE_PRESENCE (new) = presence;
2011 va_start (var_args, caps);
2014 new->fixed &= caps->fixed;
2015 thecaps = gst_caps_append (thecaps, caps);
2016 caps = va_arg (var_args, GstCaps*);
2020 GST_PADTEMPLATE_CAPS (new) = thecaps;
2026 * gst_padtemplate_get_caps:
2027 * @templ: the padtemplate to use
2029 * Get the capabilities of the padtemplate
2031 * Returns: a GstCaps*
2034 gst_padtemplate_get_caps (GstPadTemplate *templ)
2036 g_return_val_if_fail (templ != NULL, NULL);
2038 return GST_PADTEMPLATE_CAPS (templ);
2041 #ifndef GST_DISABLE_LOADSAVE
2043 * gst_padtemplate_save_thyself:
2044 * @templ: the padtemplate to save
2045 * @parent: the parent XML tree
2047 * Saves the padtemplate into XML.
2049 * Returns: the new XML tree
2052 gst_padtemplate_save_thyself (GstPadTemplate *templ, xmlNodePtr parent)
2057 GST_DEBUG (GST_CAT_XML,"saving padtemplate %s\n", templ->name_template);
2059 xmlNewChild(parent,NULL,"nametemplate", templ->name_template);
2060 xmlNewChild(parent,NULL,"direction", (templ->direction == GST_PAD_SINK? "sink":"src"));
2062 switch (templ->presence) {
2063 case GST_PAD_ALWAYS:
2064 presence = "always";
2066 case GST_PAD_SOMETIMES:
2067 presence = "sometimes";
2069 case GST_PAD_REQUEST:
2070 presence = "request";
2073 presence = "unknown";
2076 xmlNewChild(parent,NULL,"presence", presence);
2078 if (GST_PADTEMPLATE_CAPS (templ)) {
2079 subtree = xmlNewChild (parent, NULL, "caps", NULL);
2080 gst_caps_save_thyself (GST_PADTEMPLATE_CAPS (templ), subtree);
2087 * gst_padtemplate_load_thyself:
2088 * @parent: the source XML tree
2090 * Loads a padtemplate from the XML tree.
2092 * Returns: the new padtemplate
2095 gst_padtemplate_load_thyself (xmlNodePtr parent)
2097 xmlNodePtr field = parent->xmlChildrenNode;
2098 GstPadTemplate *factory;
2099 gchar *name_template = NULL;
2100 GstPadDirection direction = GST_PAD_UNKNOWN;
2101 GstPadPresence presence = GST_PAD_ALWAYS;
2102 GstCaps *caps = NULL;
2105 if (!strcmp(field->name, "nametemplate")) {
2106 name_template = xmlNodeGetContent(field);
2108 if (!strcmp(field->name, "direction")) {
2109 gchar *value = xmlNodeGetContent(field);
2111 if (!strcmp(value, "sink")) {
2112 direction = GST_PAD_SINK;
2114 else if (!strcmp(value, "src")) {
2115 direction = GST_PAD_SRC;
2119 if (!strcmp(field->name, "presence")) {
2120 gchar *value = xmlNodeGetContent(field);
2122 if (!strcmp(value, "always")) {
2123 presence = GST_PAD_ALWAYS;
2125 else if (!strcmp(value, "sometimes")) {
2126 presence = GST_PAD_SOMETIMES;
2128 else if (!strcmp(value, "request")) {
2129 presence = GST_PAD_REQUEST;
2133 else if (!strcmp(field->name, "caps")) {
2134 caps = gst_caps_load_thyself (field);
2136 field = field->next;
2139 factory = gst_padtemplate_new (name_template, direction, presence, caps, NULL);
2143 #endif /* !GST_DISABLE_LOADSAVE */
2147 * gst_pad_set_element_private:
2148 * @pad: the pad to set the private data to
2149 * @priv: The private data to attach to the pad
2151 * Set the given private data pointer to the pad. This
2152 * function can only be used by the element that own the
2156 gst_pad_set_element_private (GstPad *pad, gpointer priv)
2158 pad->element_private = priv;
2162 * gst_pad_get_element_private:
2163 * @pad: the pad to get the private data of
2165 * Get the private data of a pad. The private data can
2166 * only be set by the parent element of this pad.
2168 * Returns: a pointer to the private data.
2171 gst_pad_get_element_private (GstPad *pad)
2173 return pad->element_private;
2177 /***** ghost pads *****/
2178 GType _gst_ghost_pad_type = 0;
2180 static void gst_ghost_pad_class_init (GstGhostPadClass *klass);
2181 static void gst_ghost_pad_init (GstGhostPad *pad);
2183 static GstPad *ghost_pad_parent_class = NULL;
2184 /* static guint gst_ghost_pad_signals[LAST_SIGNAL] = { 0 }; */
2187 gst_ghost_pad_get_type(void) {
2188 if (!_gst_ghost_pad_type) {
2189 static const GTypeInfo pad_info = {
2190 sizeof(GstGhostPadClass),
2193 (GClassInitFunc)gst_ghost_pad_class_init,
2196 sizeof(GstGhostPad),
2198 (GInstanceInitFunc)gst_ghost_pad_init,
2201 _gst_ghost_pad_type = g_type_register_static(GST_TYPE_PAD, "GstGhostPad", &pad_info, 0);
2203 return _gst_ghost_pad_type;
2207 gst_ghost_pad_class_init (GstGhostPadClass *klass)
2209 GObjectClass *gobject_class;
2211 gobject_class = (GObjectClass*)klass;
2213 ghost_pad_parent_class = g_type_class_ref(GST_TYPE_PAD);
2217 gst_ghost_pad_init (GstGhostPad *pad)
2219 pad->realpad = NULL;
2223 * gst_ghost_pad_new:
2224 * @name: name of the new ghost pad
2225 * @pad: the pad to create a ghost pad of
2227 * Create a new ghost pad associated with the given pad.
2229 * Returns: new ghost pad
2232 gst_ghost_pad_new (gchar *name,
2235 GstGhostPad *ghostpad;
2237 g_return_val_if_fail (name != NULL, NULL);
2238 g_return_val_if_fail (GST_IS_PAD (pad), NULL);
2240 ghostpad = g_object_new (gst_ghost_pad_get_type () ,NULL);
2241 gst_pad_set_name (GST_PAD (ghostpad), name);
2242 GST_GPAD_REALPAD (ghostpad) = GST_PAD_REALIZE (pad);
2243 GST_PAD_PADTEMPLATE (ghostpad) = GST_PAD_PADTEMPLATE (pad);
2245 /* add ourselves to the real pad's list of ghostpads */
2246 gst_pad_add_ghost_pad (pad, GST_PAD (ghostpad));
2248 /* FIXME need to ref the real pad here... ? */
2250 GST_DEBUG (GST_CAT_PADS, "created ghost pad \"%s\"\n", name);
2252 return GST_PAD (ghostpad);
2256 gst_pad_event_default_dispatch (GstPad *pad, GstElement *element, GstEvent *event)
2258 GList *pads = element->pads;
2261 GstPad *eventpad = GST_PAD (pads->data);
2262 pads = g_list_next (pads);
2264 /* for all pads in the opposite direction that are connected */
2265 if (GST_PAD_DIRECTION (eventpad) != GST_PAD_DIRECTION (pad) && GST_PAD_IS_CONNECTED (eventpad)) {
2266 if (GST_PAD_DIRECTION (eventpad) == GST_PAD_SRC) {
2267 gst_pad_push (eventpad, GST_BUFFER (gst_event_new (GST_EVENT_TYPE (event))));
2270 GstPad *peerpad = GST_PAD_CAST (GST_RPAD_PEER (eventpad));
2272 gst_pad_send_event (peerpad, gst_event_new (GST_EVENT_TYPE (event)));
2279 * gst_pad_event_default:
2280 * @pad: the pad to operate on
2281 * @event: the event to handle
2283 * Invoke the default event handler for the given pad.
2286 gst_pad_event_default (GstPad *pad, GstEvent *event)
2288 GstElement *element = GST_PAD_PARENT (pad);
2290 g_signal_emit (G_OBJECT (pad), gst_real_pad_signals[REAL_EVENT_RECEIVED], 0, event);
2292 switch (GST_EVENT_TYPE (event)) {
2294 gst_element_set_eos (element);
2295 gst_pad_event_default_dispatch (pad, element, event);
2296 gst_event_free (event);
2297 /* we have to try to schedule another element because this one is disabled */
2298 gst_element_yield (element);
2300 case GST_EVENT_FLUSH:
2302 gst_pad_event_default_dispatch (pad, element, event);
2303 gst_event_free (event);
2309 * gst_pad_send_event:
2310 * @pad: the pad to send the event to
2311 * @event: the event to send to the pad.
2313 * Send the event to the pad.
2315 * Returns: TRUE if the event was handled.
2318 gst_pad_send_event (GstPad *pad, GstEvent *event)
2320 gboolean handled = FALSE;
2322 g_return_val_if_fail (event, FALSE);
2324 if (GST_EVENT_SRC (event) == NULL)
2325 GST_EVENT_SRC (event) = gst_object_ref (GST_OBJECT (pad));
2327 GST_DEBUG (GST_CAT_EVENT, "have event %d on pad %s:%s\n",
2328 GST_EVENT_TYPE (event), GST_DEBUG_PAD_NAME (pad));
2330 if (GST_RPAD_EVENTFUNC (pad))
2331 handled = GST_RPAD_EVENTFUNC (pad) (pad, event);
2333 GST_DEBUG(GST_CAT_EVENT, "there's no event function for pad %s:%s\n", GST_DEBUG_PAD_NAME (pad));
2337 GST_DEBUG(GST_CAT_EVENT, "proceeding with default event behavior here\n");
2338 gst_pad_event_default (pad, event);