mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-25 08:28:11 +00:00
gstreamer/pad: Add support for setting proxy pad functions on a ghost pad during construction
This commit is contained in:
parent
a80471747c
commit
07e786b44f
1 changed files with 237 additions and 0 deletions
|
@ -1856,6 +1856,243 @@ impl<T: IsA<Pad> + IsA<glib::Object>> PadBuilder<T> {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: IsA<::GhostPad> + IsA<Pad>> PadBuilder<T> {
|
impl<T: IsA<::GhostPad> + IsA<Pad>> PadBuilder<T> {
|
||||||
|
pub fn proxy_pad_activate_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>) -> Result<(), LoggableError> + Send + Sync + 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_activate_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_activatemode_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, ::PadMode, bool) -> Result<(), LoggableError>
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_activatemode_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_chain_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, ::Buffer) -> Result<FlowSuccess, FlowError>
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_chain_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_chain_list_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, ::BufferList) -> Result<FlowSuccess, FlowError>
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_chain_list_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_event_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, ::Event) -> bool + Send + Sync + 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_event_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_event_full_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, ::Event) -> Result<FlowSuccess, FlowError>
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_event_full_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_getrange_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(
|
||||||
|
&::ProxyPad,
|
||||||
|
Option<&::Object>,
|
||||||
|
u64,
|
||||||
|
Option<&mut ::BufferRef>,
|
||||||
|
u32,
|
||||||
|
) -> Result<PadGetRangeSuccess, ::FlowError>
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_getrange_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_iterate_internal_links_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>) -> ::Iterator<Pad> + Send + Sync + 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_iterate_internal_links_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_link_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, &Pad) -> Result<::PadLinkSuccess, ::PadLinkError>
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_link_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_query_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>, &mut ::QueryRef) -> bool + Send + Sync + 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_query_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_unlink_function<F>(self, func: F) -> Self
|
||||||
|
where
|
||||||
|
F: Fn(&::ProxyPad, Option<&::Object>) + Send + Sync + 'static,
|
||||||
|
{
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_unlink_function(func);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn proxy_pad_flags(self, flags: PadFlags) -> Self {
|
||||||
|
use ProxyPadExt;
|
||||||
|
|
||||||
|
unsafe {
|
||||||
|
let proxy = self
|
||||||
|
.0
|
||||||
|
.unsafe_cast_ref::<::ProxyPad>()
|
||||||
|
.get_internal()
|
||||||
|
.unwrap();
|
||||||
|
proxy.set_pad_flags(flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
pub fn build_with_target<P: IsA<Pad>>(self, target: &P) -> Result<T, glib::BoolError> {
|
pub fn build_with_target<P: IsA<Pad>>(self, target: &P) -> Result<T, glib::BoolError> {
|
||||||
use GhostPadExt;
|
use GhostPadExt;
|
||||||
use PadExt;
|
use PadExt;
|
||||||
|
|
Loading…
Reference in a new issue