mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
add parent to activate functions
This commit is contained in:
parent
285702a1a6
commit
1ad4d20607
3 changed files with 24 additions and 18 deletions
|
@ -1781,11 +1781,12 @@ static gboolean gst_ogg_demux_sink_event (GstPad * pad, GstObject * parent,
|
||||||
static void gst_ogg_demux_loop (GstOggPad * pad);
|
static void gst_ogg_demux_loop (GstOggPad * pad);
|
||||||
static GstFlowReturn gst_ogg_demux_chain (GstPad * pad, GstObject * parent,
|
static GstFlowReturn gst_ogg_demux_chain (GstPad * pad, GstObject * parent,
|
||||||
GstBuffer * buffer);
|
GstBuffer * buffer);
|
||||||
static gboolean gst_ogg_demux_sink_activate (GstPad * sinkpad);
|
static gboolean gst_ogg_demux_sink_activate (GstPad * sinkpad,
|
||||||
|
GstObject * parent);
|
||||||
static gboolean gst_ogg_demux_sink_activate_pull (GstPad * sinkpad,
|
static gboolean gst_ogg_demux_sink_activate_pull (GstPad * sinkpad,
|
||||||
gboolean active);
|
GstObject * parent, gboolean active);
|
||||||
static gboolean gst_ogg_demux_sink_activate_push (GstPad * sinkpad,
|
static gboolean gst_ogg_demux_sink_activate_push (GstPad * sinkpad,
|
||||||
gboolean active);
|
GstObject * parent, gboolean active);
|
||||||
static GstStateChangeReturn gst_ogg_demux_change_state (GstElement * element,
|
static GstStateChangeReturn gst_ogg_demux_change_state (GstElement * element,
|
||||||
GstStateChange transition);
|
GstStateChange transition);
|
||||||
|
|
||||||
|
@ -4307,7 +4308,7 @@ gst_ogg_demux_clear_chains (GstOggDemux * ogg)
|
||||||
* pull based.
|
* pull based.
|
||||||
*/
|
*/
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_ogg_demux_sink_activate (GstPad * sinkpad)
|
gst_ogg_demux_sink_activate (GstPad * sinkpad, GstObject * parent)
|
||||||
{
|
{
|
||||||
GstQuery *query;
|
GstQuery *query;
|
||||||
gboolean pull_mode;
|
gboolean pull_mode;
|
||||||
|
@ -4338,11 +4339,12 @@ activate_push:
|
||||||
/* this function gets called when we activate ourselves in push mode.
|
/* this function gets called when we activate ourselves in push mode.
|
||||||
* We cannot seek (ourselves) in the stream */
|
* We cannot seek (ourselves) in the stream */
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_ogg_demux_sink_activate_push (GstPad * sinkpad, gboolean active)
|
gst_ogg_demux_sink_activate_push (GstPad * sinkpad, GstObject * parent,
|
||||||
|
gboolean active)
|
||||||
{
|
{
|
||||||
GstOggDemux *ogg;
|
GstOggDemux *ogg;
|
||||||
|
|
||||||
ogg = GST_OGG_DEMUX (GST_OBJECT_PARENT (sinkpad));
|
ogg = GST_OGG_DEMUX (parent);
|
||||||
|
|
||||||
ogg->pullmode = FALSE;
|
ogg->pullmode = FALSE;
|
||||||
ogg->resync = FALSE;
|
ogg->resync = FALSE;
|
||||||
|
@ -4354,11 +4356,12 @@ gst_ogg_demux_sink_activate_push (GstPad * sinkpad, gboolean active)
|
||||||
* We can perform random access to the resource and we start a task
|
* We can perform random access to the resource and we start a task
|
||||||
* to start reading */
|
* to start reading */
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_ogg_demux_sink_activate_pull (GstPad * sinkpad, gboolean active)
|
gst_ogg_demux_sink_activate_pull (GstPad * sinkpad, GstObject * parent,
|
||||||
|
gboolean active)
|
||||||
{
|
{
|
||||||
GstOggDemux *ogg;
|
GstOggDemux *ogg;
|
||||||
|
|
||||||
ogg = GST_OGG_DEMUX (GST_OBJECT_PARENT (sinkpad));
|
ogg = GST_OGG_DEMUX (parent);
|
||||||
|
|
||||||
if (active) {
|
if (active) {
|
||||||
ogg->need_chains = TRUE;
|
ogg->need_chains = TRUE;
|
||||||
|
|
|
@ -294,7 +294,7 @@ static void gst_audio_encoder_get_property (GObject * object,
|
||||||
guint prop_id, GValue * value, GParamSpec * pspec);
|
guint prop_id, GValue * value, GParamSpec * pspec);
|
||||||
|
|
||||||
static gboolean gst_audio_encoder_sink_activate_push (GstPad * pad,
|
static gboolean gst_audio_encoder_sink_activate_push (GstPad * pad,
|
||||||
gboolean active);
|
GstObject * parent, gboolean active);
|
||||||
|
|
||||||
static GstCaps *gst_audio_encoder_getcaps_default (GstAudioEncoder * enc,
|
static GstCaps *gst_audio_encoder_getcaps_default (GstAudioEncoder * enc,
|
||||||
GstCaps * filter);
|
GstCaps * filter);
|
||||||
|
@ -1701,12 +1701,13 @@ gst_audio_encoder_activate (GstAudioEncoder * enc, gboolean active)
|
||||||
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_audio_encoder_sink_activate_push (GstPad * pad, gboolean active)
|
gst_audio_encoder_sink_activate_push (GstPad * pad, GstObject * parent,
|
||||||
|
gboolean active)
|
||||||
{
|
{
|
||||||
gboolean result = TRUE;
|
gboolean result = TRUE;
|
||||||
GstAudioEncoder *enc;
|
GstAudioEncoder *enc;
|
||||||
|
|
||||||
enc = GST_AUDIO_ENCODER (gst_pad_get_parent (pad));
|
enc = GST_AUDIO_ENCODER (parent);
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (enc, "sink activate push %d", active);
|
GST_DEBUG_OBJECT (enc, "sink activate push %d", active);
|
||||||
|
|
||||||
|
@ -1717,7 +1718,6 @@ gst_audio_encoder_sink_activate_push (GstPad * pad, gboolean active)
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (enc, "sink activate push return: %d", result);
|
GST_DEBUG_OBJECT (enc, "sink activate push return: %d", result);
|
||||||
|
|
||||||
gst_object_unref (enc);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -139,7 +139,8 @@ static GstFlowReturn gst_tag_demux_chain (GstPad * pad, GstObject * parent,
|
||||||
static gboolean gst_tag_demux_sink_event (GstPad * pad, GstObject * parent,
|
static gboolean gst_tag_demux_sink_event (GstPad * pad, GstObject * parent,
|
||||||
GstEvent * event);
|
GstEvent * event);
|
||||||
|
|
||||||
static gboolean gst_tag_demux_src_activate_pull (GstPad * pad, gboolean active);
|
static gboolean gst_tag_demux_src_activate_pull (GstPad * pad,
|
||||||
|
GstObject * parent, gboolean active);
|
||||||
static GstFlowReturn gst_tag_demux_read_range (GstTagDemux * tagdemux,
|
static GstFlowReturn gst_tag_demux_read_range (GstTagDemux * tagdemux,
|
||||||
GstObject * parent, guint64 offset, guint length, GstBuffer ** buffer);
|
GstObject * parent, guint64 offset, guint length, GstBuffer ** buffer);
|
||||||
|
|
||||||
|
@ -151,7 +152,8 @@ static void gst_tag_demux_set_src_caps (GstTagDemux * tagdemux,
|
||||||
|
|
||||||
static gboolean gst_tag_demux_srcpad_event (GstPad * pad, GstObject * parent,
|
static gboolean gst_tag_demux_srcpad_event (GstPad * pad, GstObject * parent,
|
||||||
GstEvent * event);
|
GstEvent * event);
|
||||||
static gboolean gst_tag_demux_sink_activate (GstPad * sinkpad);
|
static gboolean gst_tag_demux_sink_activate (GstPad * sinkpad,
|
||||||
|
GstObject * parent);
|
||||||
static GstStateChangeReturn gst_tag_demux_change_state (GstElement * element,
|
static GstStateChangeReturn gst_tag_demux_change_state (GstElement * element,
|
||||||
GstStateChange transition);
|
GstStateChange transition);
|
||||||
static gboolean gst_tag_demux_pad_query (GstPad * pad, GstObject * parent,
|
static gboolean gst_tag_demux_pad_query (GstPad * pad, GstObject * parent,
|
||||||
|
@ -1092,7 +1094,7 @@ done:
|
||||||
* otherwise activate both pads in push mode and succeed.
|
* otherwise activate both pads in push mode and succeed.
|
||||||
*/
|
*/
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_tag_demux_sink_activate (GstPad * sinkpad)
|
gst_tag_demux_sink_activate (GstPad * sinkpad, GstObject * parent)
|
||||||
{
|
{
|
||||||
GstTypeFindProbability probability = 0;
|
GstTypeFindProbability probability = 0;
|
||||||
GstTagDemuxClass *klass;
|
GstTagDemuxClass *klass;
|
||||||
|
@ -1105,7 +1107,7 @@ gst_tag_demux_sink_activate (GstPad * sinkpad)
|
||||||
GstQuery *query;
|
GstQuery *query;
|
||||||
gboolean pull_mode;
|
gboolean pull_mode;
|
||||||
|
|
||||||
demux = GST_TAG_DEMUX (GST_PAD_PARENT (sinkpad));
|
demux = GST_TAG_DEMUX (parent);
|
||||||
klass = GST_TAG_DEMUX_CLASS (G_OBJECT_GET_CLASS (demux));
|
klass = GST_TAG_DEMUX_CLASS (G_OBJECT_GET_CLASS (demux));
|
||||||
|
|
||||||
/* 1: */
|
/* 1: */
|
||||||
|
@ -1229,9 +1231,10 @@ activate_push:
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_tag_demux_src_activate_pull (GstPad * pad, gboolean active)
|
gst_tag_demux_src_activate_pull (GstPad * pad, GstObject * parent,
|
||||||
|
gboolean active)
|
||||||
{
|
{
|
||||||
GstTagDemux *demux = GST_TAG_DEMUX (GST_PAD_PARENT (pad));
|
GstTagDemux *demux = GST_TAG_DEMUX (parent);
|
||||||
|
|
||||||
return gst_pad_activate_pull (demux->priv->sinkpad, active);
|
return gst_pad_activate_pull (demux->priv->sinkpad, active);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue