From b6dc9f9bf2befbd0a3606e99fe1ec744b11c245a Mon Sep 17 00:00:00 2001 From: Zeeshan Ali Date: Fri, 25 May 2007 12:31:16 +0000 Subject: [MOVED FROM GST-P-FARSIGHT] Return correct value from the event handler 20070525123116-f3f1e-131b37b5f4521618fe2f1320409a47e65b35ad2d.gz --- gst/rtpmux/gstrtpmux.c | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) (limited to 'gst') diff --git a/gst/rtpmux/gstrtpmux.c b/gst/rtpmux/gstrtpmux.c index 08ff73f8..7fa13ab3 100644 --- a/gst/rtpmux/gstrtpmux.c +++ b/gst/rtpmux/gstrtpmux.c @@ -184,21 +184,24 @@ gst_rtp_mux_class_init (GstRTPMuxClass * klass) static gboolean gst_rtp_mux_src_event (GstPad * pad, GstEvent * event) { - gboolean result = TRUE; - GList *orig, *pads; - - orig = pads = gst_pad_get_internal_links (pad); + GstElement *rtp_mux; + GstIterator *iter; + GstPad *sinkpad; + gboolean result = FALSE; + + rtp_mux = gst_pad_get_parent_element (pad); + g_return_val_if_fail (rtp_mux != NULL, FALSE); - while (pads) { - GstPad *eventpad = GST_PAD_CAST (pads->data); - pads = g_list_next (pads); + iter = gst_element_iterate_sink_pads (rtp_mux); + while (gst_iterator_next (iter, (gpointer) &sinkpad) == GST_ITERATOR_OK) { gst_event_ref (event); - result &= gst_pad_push_event (eventpad, event); + result = gst_pad_push_event (sinkpad, event); + gst_object_unref (sinkpad); + if (result) + break; } - g_list_free (orig); - gst_event_unref (event); return result; -- cgit v1.2.1