diff options
author | Wim Taymans <wim.taymans@collabora.co.uk> | 2010-12-21 15:02:18 +0100 |
---|---|---|
committer | Wim Taymans <wim.taymans@collabora.co.uk> | 2010-12-21 15:02:18 +0100 |
commit | 9e787a0211c4220c80e62a4f4a2de4e2c457a2a0 (patch) | |
tree | d25117946190a0b1bb6bb798a489e0156535c2c3 | |
parent | 1dafd7136d4f365d9ff91b4d18a62e072481a704 (diff) |
rtpdepayloade: add support for getting events
Add support for intercepting sink events in the depayloader by adding a new
vmethod.
-rw-r--r-- | gst-libs/gst/rtp/gstbasertpdepayload.c | 25 | ||||
-rw-r--r-- | gst-libs/gst/rtp/gstbasertpdepayload.h | 6 |
2 files changed, 26 insertions, 5 deletions
diff --git a/gst-libs/gst/rtp/gstbasertpdepayload.c b/gst-libs/gst/rtp/gstbasertpdepayload.c index 583754fda..d1d39916d 100644 --- a/gst-libs/gst/rtp/gstbasertpdepayload.c +++ b/gst-libs/gst/rtp/gstbasertpdepayload.c @@ -97,6 +97,8 @@ static void gst_base_rtp_depayload_set_gst_timestamp (GstBaseRTPDepayload * filter, guint32 rtptime, GstBuffer * buf); static gboolean gst_base_rtp_depayload_packet_lost (GstBaseRTPDepayload * filter, GstEvent * event); +static gboolean gst_base_rtp_depayload_handle_event (GstBaseRTPDepayload * + filter, GstEvent * event); GST_BOILERPLATE (GstBaseRTPDepayload, gst_base_rtp_depayload, GstElement, GST_TYPE_ELEMENT); @@ -142,6 +144,7 @@ gst_base_rtp_depayload_class_init (GstBaseRTPDepayloadClass * klass) klass->set_gst_timestamp = gst_base_rtp_depayload_set_gst_timestamp; klass->packet_lost = gst_base_rtp_depayload_packet_lost; + klass->handle_event = gst_base_rtp_depayload_handle_event; GST_DEBUG_CATEGORY_INIT (basertpdepayload_debug, "basertpdepayload", 0, "Base class for RTP Depayloaders"); @@ -407,14 +410,12 @@ no_process: } static gboolean -gst_base_rtp_depayload_handle_sink_event (GstPad * pad, GstEvent * event) +gst_base_rtp_depayload_handle_event (GstBaseRTPDepayload * filter, + GstEvent * event) { - GstBaseRTPDepayload *filter; gboolean res = TRUE; gboolean forward = TRUE; - filter = GST_BASE_RTP_DEPAYLOAD (GST_OBJECT_PARENT (pad)); - switch (GST_EVENT_TYPE (event)) { case GST_EVENT_FLUSH_STOP: gst_segment_init (&filter->segment, GST_FORMAT_UNDEFINED); @@ -474,6 +475,22 @@ gst_base_rtp_depayload_handle_sink_event (GstPad * pad, GstEvent * event) return res; } +static gboolean +gst_base_rtp_depayload_handle_sink_event (GstPad * pad, GstEvent * event) +{ + gboolean res = FALSE; + GstBaseRTPDepayload *filter; + GstBaseRTPDepayloadClass *bclass; + + filter = GST_BASE_RTP_DEPAYLOAD (GST_OBJECT_PARENT (pad)); + + bclass = GST_BASE_RTP_DEPAYLOAD_GET_CLASS (filter); + if (bclass->handle_event) + res = bclass->handle_event (filter, event); + + return res; +} + static GstEvent * create_segment_event (GstBaseRTPDepayload * filter, gboolean update, GstClockTime position) diff --git a/gst-libs/gst/rtp/gstbasertpdepayload.h b/gst-libs/gst/rtp/gstbasertpdepayload.h index 4ba2fc4ed..bdd56a381 100644 --- a/gst-libs/gst/rtp/gstbasertpdepayload.h +++ b/gst-libs/gst/rtp/gstbasertpdepayload.h @@ -119,8 +119,12 @@ struct _GstBaseRTPDepayloadClass * The default implementation of this message pushes a segment update. */ gboolean (*packet_lost) (GstBaseRTPDepayload *filter, GstEvent *event); + /* the default implementation does the default actions for events but + * implementation can override. */ + gboolean (*handle_event) (GstBaseRTPDepayload * filter, GstEvent * event); + /*< private >*/ - gpointer _gst_reserved[GST_PADDING-1]; + gpointer _gst_reserved[GST_PADDING-2]; }; GType gst_base_rtp_depayload_get_type (void); |