mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 01:45:33 +00:00
gst/gstghostpad.c: Set pad functions unconditionally. Fixes #329105.
Original commit message from CVS: 2006-01-29 Julien MOUTTE <julien@moutte.net> * gst/gstghostpad.c: (gst_proxy_pad_set_target_unlocked): Set pad functions unconditionally. Fixes #329105.
This commit is contained in:
parent
c84db83b8e
commit
a365129ba7
2 changed files with 29 additions and 18 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2006-01-29 Julien MOUTTE <julien@moutte.net>
|
||||||
|
|
||||||
|
* gst/gstghostpad.c: (gst_proxy_pad_set_target_unlocked):
|
||||||
|
Set pad functions unconditionally. Fixes #329105.
|
||||||
|
|
||||||
2006-01-29 Sebastien Moutte <sebastien@moutte.net>
|
2006-01-29 Sebastien Moutte <sebastien@moutte.net>
|
||||||
* win32/vs8:
|
* win32/vs8:
|
||||||
add vs8 project files created by Sergey Scobich
|
add vs8 project files created by Sergey Scobich
|
||||||
|
|
|
@ -297,10 +297,6 @@ gst_proxy_pad_do_setcaps (GstPad * pad, GstCaps * caps)
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SETFUNC(member, kind) \
|
|
||||||
if (target->member) \
|
|
||||||
gst_pad_set_##kind##_function (pad, gst_proxy_pad_do_##kind)
|
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_proxy_pad_set_target_unlocked (GstPad * pad, GstPad * target)
|
gst_proxy_pad_set_target_unlocked (GstPad * pad, GstPad * target)
|
||||||
{
|
{
|
||||||
|
@ -319,23 +315,33 @@ gst_proxy_pad_set_target_unlocked (GstPad * pad, GstPad * target)
|
||||||
/* set and ref new target if any */
|
/* set and ref new target if any */
|
||||||
GST_PROXY_PAD_TARGET (pad) = gst_object_ref (target);
|
GST_PROXY_PAD_TARGET (pad) = gst_object_ref (target);
|
||||||
|
|
||||||
/* really, all these should have default implementations so I can set them
|
gst_pad_set_query_type_function (pad,
|
||||||
* in the _init() instead of here */
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_query_type));
|
||||||
SETFUNC (querytypefunc, query_type);
|
gst_pad_set_event_function (pad,
|
||||||
SETFUNC (eventfunc, event);
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_event));
|
||||||
SETFUNC (queryfunc, query);
|
gst_pad_set_query_function (pad,
|
||||||
SETFUNC (intlinkfunc, internal_link);
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_query));
|
||||||
SETFUNC (getcapsfunc, getcaps);
|
gst_pad_set_internal_link_function (pad,
|
||||||
SETFUNC (acceptcapsfunc, acceptcaps);
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_internal_link));
|
||||||
SETFUNC (fixatecapsfunc, fixatecaps);
|
gst_pad_set_getcaps_function (pad,
|
||||||
SETFUNC (setcapsfunc, setcaps);
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_getcaps));
|
||||||
|
gst_pad_set_acceptcaps_function (pad,
|
||||||
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_acceptcaps));
|
||||||
|
gst_pad_set_fixatecaps_function (pad,
|
||||||
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_fixatecaps));
|
||||||
|
gst_pad_set_setcaps_function (pad,
|
||||||
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_setcaps));
|
||||||
|
|
||||||
if (GST_PAD_DIRECTION (pad) == GST_PAD_SINK) {
|
if (GST_PAD_DIRECTION (pad) == GST_PAD_SINK) {
|
||||||
SETFUNC (bufferallocfunc, bufferalloc);
|
gst_pad_set_bufferalloc_function (pad,
|
||||||
SETFUNC (chainfunc, chain);
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_bufferalloc));
|
||||||
|
gst_pad_set_chain_function (pad,
|
||||||
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_chain));
|
||||||
} else {
|
} else {
|
||||||
SETFUNC (getrangefunc, getrange);
|
gst_pad_set_getrange_function (pad,
|
||||||
SETFUNC (checkgetrangefunc, checkgetrange);
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_getrange));
|
||||||
|
gst_pad_set_checkgetrange_function (pad,
|
||||||
|
GST_DEBUG_FUNCPTR (gst_proxy_pad_do_checkgetrange));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
Loading…
Reference in a new issue