mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-25 16:38:20 +00:00
gstreamer: Make virtual methods take wrapper of type, not parent
This commit is contained in:
parent
1d53b66858
commit
4eaf574cf8
8 changed files with 303 additions and 195 deletions
|
@ -9,6 +9,7 @@
|
||||||
use glib_sys;
|
use glib_sys;
|
||||||
use gst_sys;
|
use gst_sys;
|
||||||
|
|
||||||
|
use glib::prelude::*;
|
||||||
use glib::translate::*;
|
use glib::translate::*;
|
||||||
|
|
||||||
use super::prelude::*;
|
use super::prelude::*;
|
||||||
|
@ -20,29 +21,33 @@ use LoggableError;
|
||||||
use Message;
|
use Message;
|
||||||
|
|
||||||
pub trait BinImpl: BinImplExt + ElementImpl {
|
pub trait BinImpl: BinImplExt + ElementImpl {
|
||||||
fn add_element(&self, bin: &Bin, element: &Element) -> Result<(), LoggableError> {
|
fn add_element(&self, bin: &Self::Type, element: &Element) -> Result<(), LoggableError> {
|
||||||
self.parent_add_element(bin, element)
|
self.parent_add_element(bin, element)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn remove_element(&self, bin: &Bin, element: &Element) -> Result<(), LoggableError> {
|
fn remove_element(&self, bin: &Self::Type, element: &Element) -> Result<(), LoggableError> {
|
||||||
self.parent_remove_element(bin, element)
|
self.parent_remove_element(bin, element)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn handle_message(&self, bin: &Bin, message: Message) {
|
fn handle_message(&self, bin: &Self::Type, message: Message) {
|
||||||
self.parent_handle_message(bin, message)
|
self.parent_handle_message(bin, message)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait BinImplExt {
|
pub trait BinImplExt: ObjectSubclass {
|
||||||
fn parent_add_element(&self, bin: &Bin, element: &Element) -> Result<(), LoggableError>;
|
fn parent_add_element(&self, bin: &Self::Type, element: &Element) -> Result<(), LoggableError>;
|
||||||
|
|
||||||
fn parent_remove_element(&self, bin: &Bin, element: &Element) -> Result<(), LoggableError>;
|
fn parent_remove_element(
|
||||||
|
&self,
|
||||||
|
bin: &Self::Type,
|
||||||
|
element: &Element,
|
||||||
|
) -> Result<(), LoggableError>;
|
||||||
|
|
||||||
fn parent_handle_message(&self, bin: &Bin, message: Message);
|
fn parent_handle_message(&self, bin: &Self::Type, message: Message);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: BinImpl> BinImplExt for T {
|
impl<T: BinImpl> BinImplExt for T {
|
||||||
fn parent_add_element(&self, bin: &Bin, element: &Element) -> Result<(), LoggableError> {
|
fn parent_add_element(&self, bin: &Self::Type, element: &Element) -> Result<(), LoggableError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstBinClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstBinClass;
|
||||||
|
@ -50,14 +55,21 @@ impl<T: BinImpl> BinImplExt for T {
|
||||||
gst_loggable_error!(::CAT_RUST, "Parent function `add_element` is not defined")
|
gst_loggable_error!(::CAT_RUST, "Parent function `add_element` is not defined")
|
||||||
})?;
|
})?;
|
||||||
gst_result_from_gboolean!(
|
gst_result_from_gboolean!(
|
||||||
f(bin.to_glib_none().0, element.to_glib_none().0),
|
f(
|
||||||
|
bin.unsafe_cast_ref::<::Bin>().to_glib_none().0,
|
||||||
|
element.to_glib_none().0
|
||||||
|
),
|
||||||
::CAT_RUST,
|
::CAT_RUST,
|
||||||
"Failed to add the element using the parent function"
|
"Failed to add the element using the parent function"
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_remove_element(&self, bin: &Bin, element: &Element) -> Result<(), LoggableError> {
|
fn parent_remove_element(
|
||||||
|
&self,
|
||||||
|
bin: &Self::Type,
|
||||||
|
element: &Element,
|
||||||
|
) -> Result<(), LoggableError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstBinClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstBinClass;
|
||||||
|
@ -68,19 +80,25 @@ impl<T: BinImpl> BinImplExt for T {
|
||||||
)
|
)
|
||||||
})?;
|
})?;
|
||||||
gst_result_from_gboolean!(
|
gst_result_from_gboolean!(
|
||||||
f(bin.to_glib_none().0, element.to_glib_none().0),
|
f(
|
||||||
|
bin.unsafe_cast_ref::<::Bin>().to_glib_none().0,
|
||||||
|
element.to_glib_none().0
|
||||||
|
),
|
||||||
::CAT_RUST,
|
::CAT_RUST,
|
||||||
"Failed to remove the element using the parent function"
|
"Failed to remove the element using the parent function"
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_handle_message(&self, bin: &Bin, message: Message) {
|
fn parent_handle_message(&self, bin: &Self::Type, message: Message) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstBinClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstBinClass;
|
||||||
if let Some(ref f) = (*parent_class).handle_message {
|
if let Some(ref f) = (*parent_class).handle_message {
|
||||||
f(bin.to_glib_none().0, message.into_ptr());
|
f(
|
||||||
|
bin.unsafe_cast_ref::<::Bin>().to_glib_none().0,
|
||||||
|
message.into_ptr(),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -111,7 +129,7 @@ where
|
||||||
let wrap: Borrowed<Bin> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Bin> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
||||||
match imp.add_element(&wrap, &from_glib_none(element)) {
|
match imp.add_element(wrap.unsafe_cast_ref(), &from_glib_none(element)) {
|
||||||
Ok(()) => true,
|
Ok(()) => true,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
err.log_with_object(&*wrap);
|
err.log_with_object(&*wrap);
|
||||||
|
@ -141,7 +159,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
||||||
match imp.remove_element(&wrap, &from_glib_none(element)) {
|
match imp.remove_element(wrap.unsafe_cast_ref(), &from_glib_none(element)) {
|
||||||
Ok(()) => true,
|
Ok(()) => true,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
err.log_with_object(&*wrap);
|
err.log_with_object(&*wrap);
|
||||||
|
@ -163,6 +181,6 @@ unsafe extern "C" fn bin_handle_message<T: BinImpl>(
|
||||||
let wrap: Borrowed<Bin> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Bin> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), (), {
|
gst_panic_to_error!(&wrap, &instance.panicked(), (), {
|
||||||
imp.handle_message(&wrap, from_glib_full(message))
|
imp.handle_message(wrap.unsafe_cast_ref(), from_glib_full(message))
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,7 @@ use gobject_sys;
|
||||||
use gst_sys;
|
use gst_sys;
|
||||||
|
|
||||||
use glib;
|
use glib;
|
||||||
|
use glib::prelude::*;
|
||||||
use glib::subclass::prelude::*;
|
use glib::subclass::prelude::*;
|
||||||
use glib::translate::*;
|
use glib::translate::*;
|
||||||
|
|
||||||
|
@ -19,7 +20,7 @@ use libc;
|
||||||
use ChildProxy;
|
use ChildProxy;
|
||||||
|
|
||||||
pub trait ChildProxyImpl: ObjectImpl + Send + Sync {
|
pub trait ChildProxyImpl: ObjectImpl + Send + Sync {
|
||||||
fn get_child_by_name(&self, object: &ChildProxy, name: &str) -> Option<glib::Object> {
|
fn get_child_by_name(&self, object: &Self::Type, name: &str) -> Option<glib::Object> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let type_ = gst_sys::gst_child_proxy_get_type();
|
let type_ = gst_sys::gst_child_proxy_get_type();
|
||||||
let iface = gobject_sys::g_type_default_interface_ref(type_)
|
let iface = gobject_sys::g_type_default_interface_ref(type_)
|
||||||
|
@ -27,7 +28,7 @@ pub trait ChildProxyImpl: ObjectImpl + Send + Sync {
|
||||||
assert!(!iface.is_null());
|
assert!(!iface.is_null());
|
||||||
|
|
||||||
let ret = ((*iface).get_child_by_name.as_ref().unwrap())(
|
let ret = ((*iface).get_child_by_name.as_ref().unwrap())(
|
||||||
object.to_glib_none().0,
|
object.unsafe_cast_ref::<ChildProxy>().to_glib_none().0,
|
||||||
name.to_glib_none().0,
|
name.to_glib_none().0,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -37,11 +38,11 @@ pub trait ChildProxyImpl: ObjectImpl + Send + Sync {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_child_by_index(&self, object: &ChildProxy, index: u32) -> Option<glib::Object>;
|
fn get_child_by_index(&self, object: &Self::Type, index: u32) -> Option<glib::Object>;
|
||||||
fn get_children_count(&self, object: &ChildProxy) -> u32;
|
fn get_children_count(&self, object: &Self::Type) -> u32;
|
||||||
|
|
||||||
fn child_added(&self, _object: &ChildProxy, _child: &glib::Object, _name: &str) {}
|
fn child_added(&self, _object: &Self::Type, _child: &glib::Object, _name: &str) {}
|
||||||
fn child_removed(&self, _object: &ChildProxy, _child: &glib::Object, _name: &str) {}
|
fn child_removed(&self, _object: &Self::Type, _child: &glib::Object, _name: &str) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe impl<T: ChildProxyImpl> IsImplementable<T> for ChildProxy {
|
unsafe impl<T: ChildProxyImpl> IsImplementable<T> for ChildProxy {
|
||||||
|
@ -67,7 +68,7 @@ unsafe extern "C" fn child_proxy_get_child_by_name<T: ChildProxyImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
imp.get_child_by_name(
|
imp.get_child_by_name(
|
||||||
&from_glib_borrow(child_proxy),
|
&from_glib_borrow::<_, ChildProxy>(child_proxy).unsafe_cast_ref(),
|
||||||
&glib::GString::from_glib_borrow(name),
|
&glib::GString::from_glib_borrow(name),
|
||||||
)
|
)
|
||||||
.to_glib_full()
|
.to_glib_full()
|
||||||
|
@ -80,7 +81,10 @@ unsafe extern "C" fn child_proxy_get_child_by_index<T: ChildProxyImpl>(
|
||||||
let instance = &*(child_proxy as *mut T::Instance);
|
let instance = &*(child_proxy as *mut T::Instance);
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
imp.get_child_by_index(&from_glib_borrow(child_proxy), index)
|
imp.get_child_by_index(
|
||||||
|
&from_glib_borrow::<_, ChildProxy>(child_proxy).unsafe_cast_ref(),
|
||||||
|
index,
|
||||||
|
)
|
||||||
.to_glib_full()
|
.to_glib_full()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,7 +94,7 @@ unsafe extern "C" fn child_proxy_get_children_count<T: ChildProxyImpl>(
|
||||||
let instance = &*(child_proxy as *mut T::Instance);
|
let instance = &*(child_proxy as *mut T::Instance);
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
imp.get_children_count(&from_glib_borrow(child_proxy))
|
imp.get_children_count(&from_glib_borrow::<_, ChildProxy>(child_proxy).unsafe_cast_ref())
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn child_proxy_child_added<T: ChildProxyImpl>(
|
unsafe extern "C" fn child_proxy_child_added<T: ChildProxyImpl>(
|
||||||
|
@ -102,7 +106,7 @@ unsafe extern "C" fn child_proxy_child_added<T: ChildProxyImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
imp.child_added(
|
imp.child_added(
|
||||||
&from_glib_borrow(child_proxy),
|
&from_glib_borrow::<_, ChildProxy>(child_proxy).unsafe_cast_ref(),
|
||||||
&from_glib_borrow(child),
|
&from_glib_borrow(child),
|
||||||
&glib::GString::from_glib_borrow(name),
|
&glib::GString::from_glib_borrow(name),
|
||||||
)
|
)
|
||||||
|
@ -117,7 +121,7 @@ unsafe extern "C" fn child_proxy_child_removed<T: ChildProxyImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
imp.child_removed(
|
imp.child_removed(
|
||||||
&from_glib_borrow(child_proxy),
|
&from_glib_borrow::<_, ChildProxy>(child_proxy).unsafe_cast_ref(),
|
||||||
&from_glib_borrow(child),
|
&from_glib_borrow(child),
|
||||||
&glib::GString::from_glib_borrow(name),
|
&glib::GString::from_glib_borrow(name),
|
||||||
)
|
)
|
||||||
|
|
|
@ -24,59 +24,63 @@ use ClockTimeDiff;
|
||||||
pub trait ClockImpl: ClockImplExt + ObjectImpl + Send + Sync {
|
pub trait ClockImpl: ClockImplExt + ObjectImpl + Send + Sync {
|
||||||
fn change_resolution(
|
fn change_resolution(
|
||||||
&self,
|
&self,
|
||||||
clock: &Clock,
|
clock: &Self::Type,
|
||||||
old_resolution: ClockTime,
|
old_resolution: ClockTime,
|
||||||
new_resolution: ClockTime,
|
new_resolution: ClockTime,
|
||||||
) -> ClockTime {
|
) -> ClockTime {
|
||||||
self.parent_change_resolution(clock, old_resolution, new_resolution)
|
self.parent_change_resolution(clock, old_resolution, new_resolution)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_resolution(&self, clock: &Clock) -> ClockTime {
|
fn get_resolution(&self, clock: &Self::Type) -> ClockTime {
|
||||||
self.parent_get_resolution(clock)
|
self.parent_get_resolution(clock)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_internal_time(&self, clock: &Clock) -> ClockTime {
|
fn get_internal_time(&self, clock: &Self::Type) -> ClockTime {
|
||||||
self.parent_get_internal_time(clock)
|
self.parent_get_internal_time(clock)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn wait(
|
fn wait(
|
||||||
&self,
|
&self,
|
||||||
clock: &Clock,
|
clock: &Self::Type,
|
||||||
id: &ClockId,
|
id: &ClockId,
|
||||||
) -> (Result<ClockSuccess, ClockError>, ClockTimeDiff) {
|
) -> (Result<ClockSuccess, ClockError>, ClockTimeDiff) {
|
||||||
self.parent_wait(clock, id)
|
self.parent_wait(clock, id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn wait_async(&self, clock: &Clock, id: &ClockId) -> Result<ClockSuccess, ClockError> {
|
fn wait_async(&self, clock: &Self::Type, id: &ClockId) -> Result<ClockSuccess, ClockError> {
|
||||||
self.parent_wait_async(clock, id)
|
self.parent_wait_async(clock, id)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn unschedule(&self, clock: &Clock, id: &ClockId) {
|
fn unschedule(&self, clock: &Self::Type, id: &ClockId) {
|
||||||
self.parent_unschedule(clock, id)
|
self.parent_unschedule(clock, id)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait ClockImplExt {
|
pub trait ClockImplExt: ObjectSubclass {
|
||||||
fn parent_change_resolution(
|
fn parent_change_resolution(
|
||||||
&self,
|
&self,
|
||||||
clock: &Clock,
|
clock: &Self::Type,
|
||||||
old_resolution: ClockTime,
|
old_resolution: ClockTime,
|
||||||
new_resolution: ClockTime,
|
new_resolution: ClockTime,
|
||||||
) -> ClockTime;
|
) -> ClockTime;
|
||||||
|
|
||||||
fn parent_get_resolution(&self, clock: &Clock) -> ClockTime;
|
fn parent_get_resolution(&self, clock: &Self::Type) -> ClockTime;
|
||||||
|
|
||||||
fn parent_get_internal_time(&self, clock: &Clock) -> ClockTime;
|
fn parent_get_internal_time(&self, clock: &Self::Type) -> ClockTime;
|
||||||
|
|
||||||
fn parent_wait(
|
fn parent_wait(
|
||||||
&self,
|
&self,
|
||||||
clock: &Clock,
|
clock: &Self::Type,
|
||||||
id: &ClockId,
|
id: &ClockId,
|
||||||
) -> (Result<ClockSuccess, ClockError>, ClockTimeDiff);
|
) -> (Result<ClockSuccess, ClockError>, ClockTimeDiff);
|
||||||
|
|
||||||
fn parent_wait_async(&self, clock: &Clock, id: &ClockId) -> Result<ClockSuccess, ClockError>;
|
fn parent_wait_async(
|
||||||
|
&self,
|
||||||
|
clock: &Self::Type,
|
||||||
|
id: &ClockId,
|
||||||
|
) -> Result<ClockSuccess, ClockError>;
|
||||||
|
|
||||||
fn parent_unschedule(&self, clock: &Clock, id: &ClockId);
|
fn parent_unschedule(&self, clock: &Self::Type, id: &ClockId);
|
||||||
|
|
||||||
fn wake_id(&self, id: &ClockId)
|
fn wake_id(&self, id: &ClockId)
|
||||||
where
|
where
|
||||||
|
@ -87,7 +91,7 @@ pub trait ClockImplExt {
|
||||||
impl<T: ClockImpl> ClockImplExt for T {
|
impl<T: ClockImpl> ClockImplExt for T {
|
||||||
fn parent_change_resolution(
|
fn parent_change_resolution(
|
||||||
&self,
|
&self,
|
||||||
clock: &Clock,
|
clock: &Self::Type,
|
||||||
old_resolution: ClockTime,
|
old_resolution: ClockTime,
|
||||||
new_resolution: ClockTime,
|
new_resolution: ClockTime,
|
||||||
) -> ClockTime {
|
) -> ClockTime {
|
||||||
|
@ -97,7 +101,7 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
|
|
||||||
if let Some(func) = (*parent_class).change_resolution {
|
if let Some(func) = (*parent_class).change_resolution {
|
||||||
from_glib(func(
|
from_glib(func(
|
||||||
clock.to_glib_none().0,
|
clock.unsafe_cast_ref::<Clock>().to_glib_none().0,
|
||||||
old_resolution.to_glib(),
|
old_resolution.to_glib(),
|
||||||
new_resolution.to_glib(),
|
new_resolution.to_glib(),
|
||||||
))
|
))
|
||||||
|
@ -107,7 +111,7 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_get_resolution(&self, clock: &Clock) -> ClockTime {
|
fn parent_get_resolution(&self, clock: &Self::Type) -> ClockTime {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
||||||
|
@ -115,13 +119,13 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
from_glib(
|
from_glib(
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.get_resolution
|
.get_resolution
|
||||||
.map(|f| f(clock.to_glib_none().0))
|
.map(|f| f(clock.unsafe_cast_ref::<Clock>().to_glib_none().0))
|
||||||
.unwrap_or(1),
|
.unwrap_or(1),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_get_internal_time(&self, clock: &Clock) -> ClockTime {
|
fn parent_get_internal_time(&self, clock: &Self::Type) -> ClockTime {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
||||||
|
@ -129,7 +133,7 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
from_glib(
|
from_glib(
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.get_internal_time
|
.get_internal_time
|
||||||
.map(|f| f(clock.to_glib_none().0))
|
.map(|f| f(clock.unsafe_cast_ref::<Clock>().to_glib_none().0))
|
||||||
.unwrap_or(0),
|
.unwrap_or(0),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -137,7 +141,7 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
|
|
||||||
fn parent_wait(
|
fn parent_wait(
|
||||||
&self,
|
&self,
|
||||||
clock: &Clock,
|
clock: &Self::Type,
|
||||||
id: &ClockId,
|
id: &ClockId,
|
||||||
) -> (Result<ClockSuccess, ClockError>, ClockTimeDiff) {
|
) -> (Result<ClockSuccess, ClockError>, ClockTimeDiff) {
|
||||||
unsafe {
|
unsafe {
|
||||||
|
@ -151,7 +155,7 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
.wait
|
.wait
|
||||||
.map(|f| {
|
.map(|f| {
|
||||||
f(
|
f(
|
||||||
clock.to_glib_none().0,
|
clock.unsafe_cast_ref::<Clock>().to_glib_none().0,
|
||||||
id.to_glib_none().0 as *mut gst_sys::GstClockEntry,
|
id.to_glib_none().0 as *mut gst_sys::GstClockEntry,
|
||||||
&mut jitter,
|
&mut jitter,
|
||||||
)
|
)
|
||||||
|
@ -164,7 +168,11 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_wait_async(&self, clock: &Clock, id: &ClockId) -> Result<ClockSuccess, ClockError> {
|
fn parent_wait_async(
|
||||||
|
&self,
|
||||||
|
clock: &Self::Type,
|
||||||
|
id: &ClockId,
|
||||||
|
) -> Result<ClockSuccess, ClockError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
||||||
|
@ -173,7 +181,7 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
.wait_async
|
.wait_async
|
||||||
.map(|f| {
|
.map(|f| {
|
||||||
f(
|
f(
|
||||||
clock.to_glib_none().0,
|
clock.unsafe_cast_ref::<Clock>().to_glib_none().0,
|
||||||
id.to_glib_none().0 as *mut gst_sys::GstClockEntry,
|
id.to_glib_none().0 as *mut gst_sys::GstClockEntry,
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
@ -183,13 +191,13 @@ impl<T: ClockImpl> ClockImplExt for T {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_unschedule(&self, clock: &Clock, id: &ClockId) {
|
fn parent_unschedule(&self, clock: &Self::Type, id: &ClockId) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstClockClass;
|
||||||
if let Some(func) = (*parent_class).unschedule {
|
if let Some(func) = (*parent_class).unschedule {
|
||||||
func(
|
func(
|
||||||
clock.to_glib_none().0,
|
clock.unsafe_cast_ref::<Clock>().to_glib_none().0,
|
||||||
id.to_glib_none().0 as *mut gst_sys::GstClockEntry,
|
id.to_glib_none().0 as *mut gst_sys::GstClockEntry,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -254,7 +262,11 @@ unsafe extern "C" fn clock_change_resolution<T: ClockImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.change_resolution(&wrap, from_glib(old_resolution), from_glib(new_resolution))
|
imp.change_resolution(
|
||||||
|
wrap.unsafe_cast_ref(),
|
||||||
|
from_glib(old_resolution),
|
||||||
|
from_glib(new_resolution),
|
||||||
|
)
|
||||||
.to_glib()
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -265,7 +277,7 @@ unsafe extern "C" fn clock_get_resolution<T: ClockImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.get_resolution(&wrap).to_glib()
|
imp.get_resolution(wrap.unsafe_cast_ref()).to_glib()
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn clock_get_internal_time<T: ClockImpl>(
|
unsafe extern "C" fn clock_get_internal_time<T: ClockImpl>(
|
||||||
|
@ -275,7 +287,7 @@ unsafe extern "C" fn clock_get_internal_time<T: ClockImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.get_internal_time(&wrap).to_glib()
|
imp.get_internal_time(wrap.unsafe_cast_ref()).to_glib()
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn clock_wait<T: ClockImpl>(
|
unsafe extern "C" fn clock_wait<T: ClockImpl>(
|
||||||
|
@ -287,7 +299,10 @@ unsafe extern "C" fn clock_wait<T: ClockImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
let (res, j) = imp.wait(&wrap, &from_glib_borrow(id as gst_sys::GstClockID));
|
let (res, j) = imp.wait(
|
||||||
|
wrap.unsafe_cast_ref(),
|
||||||
|
&from_glib_borrow(id as gst_sys::GstClockID),
|
||||||
|
);
|
||||||
if !jitter.is_null() {
|
if !jitter.is_null() {
|
||||||
*jitter = j;
|
*jitter = j;
|
||||||
}
|
}
|
||||||
|
@ -303,7 +318,11 @@ unsafe extern "C" fn clock_wait_async<T: ClockImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
ClockReturn::from(imp.wait_async(&wrap, &from_glib_borrow(id as gst_sys::GstClockID))).to_glib()
|
ClockReturn::from(imp.wait_async(
|
||||||
|
wrap.unsafe_cast_ref(),
|
||||||
|
&from_glib_borrow(id as gst_sys::GstClockID),
|
||||||
|
))
|
||||||
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn clock_unschedule<T: ClockImpl>(
|
unsafe extern "C" fn clock_unschedule<T: ClockImpl>(
|
||||||
|
@ -314,5 +333,8 @@ unsafe extern "C" fn clock_unschedule<T: ClockImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Clock> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.unschedule(&wrap, &from_glib_borrow(id as gst_sys::GstClockID));
|
imp.unschedule(
|
||||||
|
wrap.unsafe_cast_ref(),
|
||||||
|
&from_glib_borrow(id as gst_sys::GstClockID),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,9 +9,9 @@
|
||||||
use glib_sys;
|
use glib_sys;
|
||||||
use gst_sys;
|
use gst_sys;
|
||||||
|
|
||||||
use glib::translate::*;
|
use glib::prelude::*;
|
||||||
|
|
||||||
use glib::subclass::prelude::*;
|
use glib::subclass::prelude::*;
|
||||||
|
use glib::translate::*;
|
||||||
|
|
||||||
use Device;
|
use Device;
|
||||||
use Element;
|
use Element;
|
||||||
|
@ -22,27 +22,31 @@ use std::ptr;
|
||||||
pub trait DeviceImpl: DeviceImplExt + ObjectImpl + Send + Sync {
|
pub trait DeviceImpl: DeviceImplExt + ObjectImpl + Send + Sync {
|
||||||
fn create_element(
|
fn create_element(
|
||||||
&self,
|
&self,
|
||||||
device: &Device,
|
device: &Self::Type,
|
||||||
name: Option<&str>,
|
name: Option<&str>,
|
||||||
) -> Result<Element, LoggableError> {
|
) -> Result<Element, LoggableError> {
|
||||||
self.parent_create_element(device, name)
|
self.parent_create_element(device, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn reconfigure_element(&self, device: &Device, element: &Element) -> Result<(), LoggableError> {
|
fn reconfigure_element(
|
||||||
|
&self,
|
||||||
|
device: &Self::Type,
|
||||||
|
element: &Element,
|
||||||
|
) -> Result<(), LoggableError> {
|
||||||
self.parent_reconfigure_element(device, element)
|
self.parent_reconfigure_element(device, element)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait DeviceImplExt {
|
pub trait DeviceImplExt: ObjectSubclass {
|
||||||
fn parent_create_element(
|
fn parent_create_element(
|
||||||
&self,
|
&self,
|
||||||
device: &Device,
|
device: &Self::Type,
|
||||||
name: Option<&str>,
|
name: Option<&str>,
|
||||||
) -> Result<Element, LoggableError>;
|
) -> Result<Element, LoggableError>;
|
||||||
|
|
||||||
fn parent_reconfigure_element(
|
fn parent_reconfigure_element(
|
||||||
&self,
|
&self,
|
||||||
device: &Device,
|
device: &Self::Type,
|
||||||
element: &Element,
|
element: &Element,
|
||||||
) -> Result<(), LoggableError>;
|
) -> Result<(), LoggableError>;
|
||||||
}
|
}
|
||||||
|
@ -50,14 +54,17 @@ pub trait DeviceImplExt {
|
||||||
impl<T: DeviceImpl> DeviceImplExt for T {
|
impl<T: DeviceImpl> DeviceImplExt for T {
|
||||||
fn parent_create_element(
|
fn parent_create_element(
|
||||||
&self,
|
&self,
|
||||||
device: &Device,
|
device: &Self::Type,
|
||||||
name: Option<&str>,
|
name: Option<&str>,
|
||||||
) -> Result<Element, LoggableError> {
|
) -> Result<Element, LoggableError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstDeviceClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstDeviceClass;
|
||||||
if let Some(f) = (*parent_class).create_element {
|
if let Some(f) = (*parent_class).create_element {
|
||||||
let ptr = f(device.to_glib_none().0, name.to_glib_none().0);
|
let ptr = f(
|
||||||
|
device.unsafe_cast_ref::<Device>().to_glib_none().0,
|
||||||
|
name.to_glib_none().0,
|
||||||
|
);
|
||||||
|
|
||||||
// Don't steal floating reference here but pass it further to the caller
|
// Don't steal floating reference here but pass it further to the caller
|
||||||
Option::<_>::from_glib_full(ptr).ok_or_else(|| {
|
Option::<_>::from_glib_full(ptr).ok_or_else(|| {
|
||||||
|
@ -77,7 +84,7 @@ impl<T: DeviceImpl> DeviceImplExt for T {
|
||||||
|
|
||||||
fn parent_reconfigure_element(
|
fn parent_reconfigure_element(
|
||||||
&self,
|
&self,
|
||||||
device: &Device,
|
device: &Self::Type,
|
||||||
element: &Element,
|
element: &Element,
|
||||||
) -> Result<(), LoggableError> {
|
) -> Result<(), LoggableError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
|
@ -90,7 +97,10 @@ impl<T: DeviceImpl> DeviceImplExt for T {
|
||||||
)
|
)
|
||||||
})?;
|
})?;
|
||||||
gst_result_from_gboolean!(
|
gst_result_from_gboolean!(
|
||||||
f(device.to_glib_none().0, element.to_glib_none().0),
|
f(
|
||||||
|
device.unsafe_cast_ref::<Device>().to_glib_none().0,
|
||||||
|
element.to_glib_none().0
|
||||||
|
),
|
||||||
::CAT_RUST,
|
::CAT_RUST,
|
||||||
"Failed to reconfigure the element using the parent function"
|
"Failed to reconfigure the element using the parent function"
|
||||||
)
|
)
|
||||||
|
@ -116,7 +126,7 @@ unsafe extern "C" fn device_create_element<T: DeviceImpl>(
|
||||||
let wrap: Borrowed<Device> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Device> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
match imp.create_element(
|
match imp.create_element(
|
||||||
&wrap,
|
wrap.unsafe_cast_ref(),
|
||||||
Option::<glib::GString>::from_glib_borrow(name)
|
Option::<glib::GString>::from_glib_borrow(name)
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.as_ref()
|
.as_ref()
|
||||||
|
@ -146,7 +156,7 @@ unsafe extern "C" fn device_reconfigure_element<T: DeviceImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Device> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Device> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
match imp.reconfigure_element(&wrap, &from_glib_borrow(element)) {
|
match imp.reconfigure_element(wrap.unsafe_cast_ref(), &from_glib_borrow(element)) {
|
||||||
Ok(()) => true,
|
Ok(()) => true,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
err.log_with_object(&*wrap);
|
err.log_with_object(&*wrap);
|
||||||
|
|
|
@ -9,51 +9,54 @@
|
||||||
use glib_sys;
|
use glib_sys;
|
||||||
use gst_sys;
|
use gst_sys;
|
||||||
|
|
||||||
use glib::translate::*;
|
use glib::prelude::*;
|
||||||
|
|
||||||
use glib::subclass::prelude::*;
|
use glib::subclass::prelude::*;
|
||||||
|
use glib::translate::*;
|
||||||
|
|
||||||
use Device;
|
use Device;
|
||||||
use DeviceProvider;
|
use DeviceProvider;
|
||||||
use LoggableError;
|
use LoggableError;
|
||||||
|
|
||||||
pub trait DeviceProviderImpl: DeviceProviderImplExt + ObjectImpl + Send + Sync {
|
pub trait DeviceProviderImpl: DeviceProviderImplExt + ObjectImpl + Send + Sync {
|
||||||
fn probe(&self, device_provider: &DeviceProvider) -> Vec<Device> {
|
fn probe(&self, device_provider: &Self::Type) -> Vec<Device> {
|
||||||
self.parent_probe(device_provider)
|
self.parent_probe(device_provider)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn start(&self, device_provider: &DeviceProvider) -> Result<(), LoggableError> {
|
fn start(&self, device_provider: &Self::Type) -> Result<(), LoggableError> {
|
||||||
self.parent_start(device_provider)
|
self.parent_start(device_provider)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn stop(&self, device_provider: &DeviceProvider) {
|
fn stop(&self, device_provider: &Self::Type) {
|
||||||
self.parent_stop(device_provider)
|
self.parent_stop(device_provider)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait DeviceProviderImplExt {
|
pub trait DeviceProviderImplExt: ObjectSubclass {
|
||||||
fn parent_probe(&self, device_provider: &DeviceProvider) -> Vec<Device>;
|
fn parent_probe(&self, device_provider: &Self::Type) -> Vec<Device>;
|
||||||
|
|
||||||
fn parent_start(&self, device_provider: &DeviceProvider) -> Result<(), LoggableError>;
|
fn parent_start(&self, device_provider: &Self::Type) -> Result<(), LoggableError>;
|
||||||
|
|
||||||
fn parent_stop(&self, device_provider: &DeviceProvider);
|
fn parent_stop(&self, device_provider: &Self::Type);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: DeviceProviderImpl> DeviceProviderImplExt for T {
|
impl<T: DeviceProviderImpl> DeviceProviderImplExt for T {
|
||||||
fn parent_probe(&self, device_provider: &DeviceProvider) -> Vec<Device> {
|
fn parent_probe(&self, device_provider: &Self::Type) -> Vec<Device> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class =
|
let parent_class =
|
||||||
data.as_ref().get_parent_class() as *mut gst_sys::GstDeviceProviderClass;
|
data.as_ref().get_parent_class() as *mut gst_sys::GstDeviceProviderClass;
|
||||||
if let Some(f) = (*parent_class).probe {
|
if let Some(f) = (*parent_class).probe {
|
||||||
FromGlibPtrContainer::from_glib_full(f(device_provider.to_glib_none().0))
|
FromGlibPtrContainer::from_glib_full(f(device_provider
|
||||||
|
.unsafe_cast_ref::<DeviceProvider>()
|
||||||
|
.to_glib_none()
|
||||||
|
.0))
|
||||||
} else {
|
} else {
|
||||||
Vec::new()
|
Vec::new()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_start(&self, device_provider: &DeviceProvider) -> Result<(), LoggableError> {
|
fn parent_start(&self, device_provider: &Self::Type) -> Result<(), LoggableError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class =
|
let parent_class =
|
||||||
|
@ -62,20 +65,26 @@ impl<T: DeviceProviderImpl> DeviceProviderImplExt for T {
|
||||||
gst_loggable_error!(::CAT_RUST, "Parent function `start` is not defined")
|
gst_loggable_error!(::CAT_RUST, "Parent function `start` is not defined")
|
||||||
})?;
|
})?;
|
||||||
gst_result_from_gboolean!(
|
gst_result_from_gboolean!(
|
||||||
f(device_provider.to_glib_none().0),
|
f(device_provider
|
||||||
|
.unsafe_cast_ref::<DeviceProvider>()
|
||||||
|
.to_glib_none()
|
||||||
|
.0),
|
||||||
::CAT_RUST,
|
::CAT_RUST,
|
||||||
"Failed to start the device provider using the parent function"
|
"Failed to start the device provider using the parent function"
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_stop(&self, device_provider: &DeviceProvider) {
|
fn parent_stop(&self, device_provider: &Self::Type) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class =
|
let parent_class =
|
||||||
data.as_ref().get_parent_class() as *mut gst_sys::GstDeviceProviderClass;
|
data.as_ref().get_parent_class() as *mut gst_sys::GstDeviceProviderClass;
|
||||||
if let Some(f) = (*parent_class).stop {
|
if let Some(f) = (*parent_class).stop {
|
||||||
f(device_provider.to_glib_none().0);
|
f(device_provider
|
||||||
|
.unsafe_cast_ref::<DeviceProvider>()
|
||||||
|
.to_glib_none()
|
||||||
|
.0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -130,7 +139,7 @@ unsafe extern "C" fn device_provider_probe<T: DeviceProviderImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<DeviceProvider> = from_glib_borrow(ptr);
|
let wrap: Borrowed<DeviceProvider> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.probe(&wrap).to_glib_full()
|
imp.probe(wrap.unsafe_cast_ref()).to_glib_full()
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn device_provider_start<T: DeviceProviderImpl>(
|
unsafe extern "C" fn device_provider_start<T: DeviceProviderImpl>(
|
||||||
|
@ -140,7 +149,7 @@ unsafe extern "C" fn device_provider_start<T: DeviceProviderImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<DeviceProvider> = from_glib_borrow(ptr);
|
let wrap: Borrowed<DeviceProvider> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
match imp.start(&wrap) {
|
match imp.start(wrap.unsafe_cast_ref()) {
|
||||||
Ok(()) => true,
|
Ok(()) => true,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
err.log_with_object(&*wrap);
|
err.log_with_object(&*wrap);
|
||||||
|
@ -157,5 +166,5 @@ unsafe extern "C" fn device_provider_stop<T: DeviceProviderImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<DeviceProvider> = from_glib_borrow(ptr);
|
let wrap: Borrowed<DeviceProvider> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.stop(&wrap);
|
imp.stop(wrap.unsafe_cast_ref());
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ use StateChangeSuccess;
|
||||||
pub trait ElementImpl: ElementImplExt + ObjectImpl + Send + Sync {
|
pub trait ElementImpl: ElementImplExt + ObjectImpl + Send + Sync {
|
||||||
fn change_state(
|
fn change_state(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
transition: StateChange,
|
transition: StateChange,
|
||||||
) -> Result<StateChangeSuccess, StateChangeError> {
|
) -> Result<StateChangeSuccess, StateChangeError> {
|
||||||
self.parent_change_state(element, transition)
|
self.parent_change_state(element, transition)
|
||||||
|
@ -38,7 +38,7 @@ pub trait ElementImpl: ElementImplExt + ObjectImpl + Send + Sync {
|
||||||
|
|
||||||
fn request_new_pad(
|
fn request_new_pad(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
templ: &::PadTemplate,
|
templ: &::PadTemplate,
|
||||||
name: Option<String>,
|
name: Option<String>,
|
||||||
caps: Option<&::Caps>,
|
caps: Option<&::Caps>,
|
||||||
|
@ -46,77 +46,72 @@ pub trait ElementImpl: ElementImplExt + ObjectImpl + Send + Sync {
|
||||||
self.parent_request_new_pad(element, templ, name, caps)
|
self.parent_request_new_pad(element, templ, name, caps)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn release_pad(&self, element: &::Element, pad: &::Pad) {
|
fn release_pad(&self, element: &Self::Type, pad: &::Pad) {
|
||||||
self.parent_release_pad(element, pad)
|
self.parent_release_pad(element, pad)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn send_event(&self, element: &::Element, event: Event) -> bool {
|
fn send_event(&self, element: &Self::Type, event: Event) -> bool {
|
||||||
self.parent_send_event(element, event)
|
self.parent_send_event(element, event)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn query(&self, element: &::Element, query: &mut QueryRef) -> bool {
|
fn query(&self, element: &Self::Type, query: &mut QueryRef) -> bool {
|
||||||
self.parent_query(element, query)
|
self.parent_query(element, query)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set_context(&self, element: &::Element, context: &::Context) {
|
fn set_context(&self, element: &Self::Type, context: &::Context) {
|
||||||
self.parent_set_context(element, context)
|
self.parent_set_context(element, context)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set_clock(&self, element: &::Element, clock: Option<&::Clock>) -> bool {
|
fn set_clock(&self, element: &Self::Type, clock: Option<&::Clock>) -> bool {
|
||||||
self.parent_set_clock(element, clock)
|
self.parent_set_clock(element, clock)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn provide_clock(&self, element: &::Element) -> Option<::Clock> {
|
fn provide_clock(&self, element: &Self::Type) -> Option<::Clock> {
|
||||||
self.parent_provide_clock(element)
|
self.parent_provide_clock(element)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn post_message(&self, element: &::Element, msg: ::Message) -> bool {
|
fn post_message(&self, element: &Self::Type, msg: ::Message) -> bool {
|
||||||
self.parent_post_message(element, msg)
|
self.parent_post_message(element, msg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait ElementImplExt {
|
pub trait ElementImplExt: ObjectSubclass {
|
||||||
fn parent_change_state(
|
fn parent_change_state(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
transition: StateChange,
|
transition: StateChange,
|
||||||
) -> Result<StateChangeSuccess, StateChangeError>;
|
) -> Result<StateChangeSuccess, StateChangeError>;
|
||||||
|
|
||||||
fn parent_request_new_pad(
|
fn parent_request_new_pad(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
templ: &::PadTemplate,
|
templ: &::PadTemplate,
|
||||||
name: Option<String>,
|
name: Option<String>,
|
||||||
caps: Option<&::Caps>,
|
caps: Option<&::Caps>,
|
||||||
) -> Option<::Pad>;
|
) -> Option<::Pad>;
|
||||||
|
|
||||||
fn parent_release_pad(&self, element: &::Element, pad: &::Pad);
|
fn parent_release_pad(&self, element: &Self::Type, pad: &::Pad);
|
||||||
|
|
||||||
fn parent_send_event(&self, element: &::Element, event: Event) -> bool;
|
fn parent_send_event(&self, element: &Self::Type, event: Event) -> bool;
|
||||||
|
|
||||||
fn parent_query(&self, element: &::Element, query: &mut QueryRef) -> bool;
|
fn parent_query(&self, element: &Self::Type, query: &mut QueryRef) -> bool;
|
||||||
|
|
||||||
fn parent_set_context(&self, element: &::Element, context: &::Context);
|
fn parent_set_context(&self, element: &Self::Type, context: &::Context);
|
||||||
|
|
||||||
fn parent_set_clock(&self, element: &::Element, clock: Option<&::Clock>) -> bool;
|
fn parent_set_clock(&self, element: &Self::Type, clock: Option<&::Clock>) -> bool;
|
||||||
|
|
||||||
fn parent_provide_clock(&self, element: &::Element) -> Option<::Clock>;
|
fn parent_provide_clock(&self, element: &Self::Type) -> Option<::Clock>;
|
||||||
|
|
||||||
fn parent_post_message(&self, element: &::Element, msg: ::Message) -> bool;
|
fn parent_post_message(&self, element: &Self::Type, msg: ::Message) -> bool;
|
||||||
|
|
||||||
fn catch_panic<
|
fn catch_panic<R, F: FnOnce(&Self) -> R, G: FnOnce() -> R, P: IsA<Element>>(
|
||||||
R,
|
|
||||||
F: FnOnce(&Self) -> R,
|
|
||||||
G: FnOnce() -> R,
|
|
||||||
P: IsA<::Element> + IsA<glib::Object> + glib::value::SetValue,
|
|
||||||
>(
|
|
||||||
&self,
|
&self,
|
||||||
element: &P,
|
element: &P,
|
||||||
fallback: G,
|
fallback: G,
|
||||||
f: F,
|
f: F,
|
||||||
) -> R;
|
) -> R;
|
||||||
|
|
||||||
fn catch_panic_pad_function<R, F: FnOnce(&Self, &::Element) -> R, G: FnOnce() -> R>(
|
fn catch_panic_pad_function<R, F: FnOnce(&Self, &Self::Type) -> R, G: FnOnce() -> R>(
|
||||||
parent: Option<&::Object>,
|
parent: Option<&::Object>,
|
||||||
fallback: G,
|
fallback: G,
|
||||||
f: F,
|
f: F,
|
||||||
|
@ -129,7 +124,7 @@ where
|
||||||
{
|
{
|
||||||
fn parent_change_state(
|
fn parent_change_state(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
transition: StateChange,
|
transition: StateChange,
|
||||||
) -> Result<StateChangeSuccess, StateChangeError> {
|
) -> Result<StateChangeSuccess, StateChangeError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
|
@ -139,14 +134,17 @@ where
|
||||||
let f = (*parent_class)
|
let f = (*parent_class)
|
||||||
.change_state
|
.change_state
|
||||||
.expect("Missing parent function `change_state`");
|
.expect("Missing parent function `change_state`");
|
||||||
StateChangeReturn::from_glib(f(element.to_glib_none().0, transition.to_glib()))
|
StateChangeReturn::from_glib(f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
transition.to_glib(),
|
||||||
|
))
|
||||||
.into_result()
|
.into_result()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_request_new_pad(
|
fn parent_request_new_pad(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
templ: &::PadTemplate,
|
templ: &::PadTemplate,
|
||||||
name: Option<String>,
|
name: Option<String>,
|
||||||
caps: Option<&::Caps>,
|
caps: Option<&::Caps>,
|
||||||
|
@ -159,7 +157,7 @@ where
|
||||||
.request_new_pad
|
.request_new_pad
|
||||||
.map(|f| {
|
.map(|f| {
|
||||||
from_glib_none(f(
|
from_glib_none(f(
|
||||||
element.to_glib_none().0,
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
templ.to_glib_none().0,
|
templ.to_glib_none().0,
|
||||||
name.to_glib_full(),
|
name.to_glib_full(),
|
||||||
caps.to_glib_none().0,
|
caps.to_glib_none().0,
|
||||||
|
@ -169,97 +167,120 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_release_pad(&self, element: &::Element, pad: &::Pad) {
|
fn parent_release_pad(&self, element: &Self::Type, pad: &::Pad) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.release_pad
|
.release_pad
|
||||||
.map(|f| f(element.to_glib_none().0, pad.to_glib_none().0))
|
.map(|f| {
|
||||||
|
f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
pad.to_glib_none().0,
|
||||||
|
)
|
||||||
|
})
|
||||||
.unwrap_or(())
|
.unwrap_or(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_send_event(&self, element: &::Element, event: Event) -> bool {
|
fn parent_send_event(&self, element: &Self::Type, event: Event) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.send_event
|
.send_event
|
||||||
.map(|f| from_glib(f(element.to_glib_none().0, event.into_ptr())))
|
.map(|f| {
|
||||||
|
from_glib(f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
event.into_ptr(),
|
||||||
|
))
|
||||||
|
})
|
||||||
.unwrap_or(false)
|
.unwrap_or(false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_query(&self, element: &::Element, query: &mut QueryRef) -> bool {
|
fn parent_query(&self, element: &Self::Type, query: &mut QueryRef) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.query
|
.query
|
||||||
.map(|f| from_glib(f(element.to_glib_none().0, query.as_mut_ptr())))
|
.map(|f| {
|
||||||
|
from_glib(f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
query.as_mut_ptr(),
|
||||||
|
))
|
||||||
|
})
|
||||||
.unwrap_or(false)
|
.unwrap_or(false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_set_context(&self, element: &::Element, context: &::Context) {
|
fn parent_set_context(&self, element: &Self::Type, context: &::Context) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.set_context
|
.set_context
|
||||||
.map(|f| f(element.to_glib_none().0, context.to_glib_none().0))
|
.map(|f| {
|
||||||
|
f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
context.to_glib_none().0,
|
||||||
|
)
|
||||||
|
})
|
||||||
.unwrap_or(())
|
.unwrap_or(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_set_clock(&self, element: &::Element, clock: Option<&::Clock>) -> bool {
|
fn parent_set_clock(&self, element: &Self::Type, clock: Option<&::Clock>) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.set_clock
|
.set_clock
|
||||||
.map(|f| from_glib(f(element.to_glib_none().0, clock.to_glib_none().0)))
|
.map(|f| {
|
||||||
|
from_glib(f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
clock.to_glib_none().0,
|
||||||
|
))
|
||||||
|
})
|
||||||
.unwrap_or(false)
|
.unwrap_or(false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_provide_clock(&self, element: &::Element) -> Option<::Clock> {
|
fn parent_provide_clock(&self, element: &Self::Type) -> Option<::Clock> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.provide_clock
|
.provide_clock
|
||||||
.map(|f| from_glib_none(f(element.to_glib_none().0)))
|
.map(|f| from_glib_none(f(element.unsafe_cast_ref::<Element>().to_glib_none().0)))
|
||||||
.unwrap_or(None)
|
.unwrap_or(None)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_post_message(&self, element: &::Element, msg: ::Message) -> bool {
|
fn parent_post_message(&self, element: &Self::Type, msg: ::Message) -> bool {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstElementClass;
|
||||||
|
|
||||||
if let Some(f) = (*parent_class).post_message {
|
if let Some(f) = (*parent_class).post_message {
|
||||||
from_glib(f(element.to_glib_none().0, msg.into_ptr()))
|
from_glib(f(
|
||||||
|
element.unsafe_cast_ref::<Element>().to_glib_none().0,
|
||||||
|
msg.into_ptr(),
|
||||||
|
))
|
||||||
} else {
|
} else {
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn catch_panic<
|
fn catch_panic<R, F: FnOnce(&Self) -> R, G: FnOnce() -> R, P: IsA<Element>>(
|
||||||
R,
|
|
||||||
F: FnOnce(&Self) -> R,
|
|
||||||
G: FnOnce() -> R,
|
|
||||||
P: IsA<::Element> + IsA<glib::Object> + glib::value::SetValue,
|
|
||||||
>(
|
|
||||||
&self,
|
&self,
|
||||||
element: &P,
|
element: &P,
|
||||||
fallback: G,
|
fallback: G,
|
||||||
|
@ -275,23 +296,21 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn catch_panic_pad_function<R, F: FnOnce(&Self, &::Element) -> R, G: FnOnce() -> R>(
|
fn catch_panic_pad_function<R, F: FnOnce(&Self, &Self::Type) -> R, G: FnOnce() -> R>(
|
||||||
parent: Option<&::Object>,
|
parent: Option<&::Object>,
|
||||||
fallback: G,
|
fallback: G,
|
||||||
f: F,
|
f: F,
|
||||||
) -> R {
|
) -> R {
|
||||||
unsafe {
|
unsafe {
|
||||||
let wrap = parent
|
let wrap = parent.as_ref().unwrap().downcast_ref::<Element>().unwrap();
|
||||||
.as_ref()
|
|
||||||
.unwrap()
|
|
||||||
.downcast_ref::<::Element>()
|
|
||||||
.unwrap();
|
|
||||||
assert!(wrap.get_type().is_a(&T::get_type()));
|
assert!(wrap.get_type().is_a(&T::get_type()));
|
||||||
let ptr: *mut gst_sys::GstElement = wrap.to_glib_none().0;
|
let ptr: *mut gst_sys::GstElement = wrap.to_glib_none().0;
|
||||||
let instance = &*(ptr as *mut T::Instance);
|
let instance = &*(ptr as *mut T::Instance);
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
gst_panic_to_error!(wrap, &instance.panicked(), fallback(), { f(&imp, &wrap) })
|
gst_panic_to_error!(wrap, &instance.panicked(), fallback(), {
|
||||||
|
f(&imp, wrap.unsafe_cast_ref())
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -378,7 +397,7 @@ where
|
||||||
};
|
};
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), fallback, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), fallback, {
|
||||||
imp.change_state(&wrap, transition).into()
|
imp.change_state(wrap.unsafe_cast_ref(), transition).into()
|
||||||
})
|
})
|
||||||
.to_glib()
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
@ -402,7 +421,7 @@ where
|
||||||
// See https://bugzilla.gnome.org/show_bug.cgi?id=791193
|
// See https://bugzilla.gnome.org/show_bug.cgi?id=791193
|
||||||
let pad = gst_panic_to_error!(&wrap, &instance.panicked(), None, {
|
let pad = gst_panic_to_error!(&wrap, &instance.panicked(), None, {
|
||||||
imp.request_new_pad(
|
imp.request_new_pad(
|
||||||
&wrap,
|
wrap.unsafe_cast_ref(),
|
||||||
&from_glib_borrow(templ),
|
&from_glib_borrow(templ),
|
||||||
from_glib_none(name),
|
from_glib_none(name),
|
||||||
caps.as_ref().as_ref(),
|
caps.as_ref().as_ref(),
|
||||||
|
@ -437,7 +456,7 @@ unsafe extern "C" fn element_release_pad<T: ElementImpl>(
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), (), {
|
gst_panic_to_error!(&wrap, &instance.panicked(), (), {
|
||||||
imp.release_pad(&wrap, &from_glib_none(pad))
|
imp.release_pad(wrap.unsafe_cast_ref(), &from_glib_none(pad))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -453,7 +472,7 @@ where
|
||||||
let wrap: Borrowed<Element> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Element> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
||||||
imp.send_event(&wrap, from_glib_full(event))
|
imp.send_event(wrap.unsafe_cast_ref(), from_glib_full(event))
|
||||||
})
|
})
|
||||||
.to_glib()
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
@ -471,7 +490,7 @@ where
|
||||||
let query = QueryRef::from_mut_ptr(query);
|
let query = QueryRef::from_mut_ptr(query);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
||||||
imp.query(&wrap, query)
|
imp.query(wrap.unsafe_cast_ref(), query)
|
||||||
})
|
})
|
||||||
.to_glib()
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
@ -487,7 +506,7 @@ unsafe extern "C" fn element_set_context<T: ElementImpl>(
|
||||||
let wrap: Borrowed<Element> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Element> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), (), {
|
gst_panic_to_error!(&wrap, &instance.panicked(), (), {
|
||||||
imp.set_context(&wrap, &from_glib_borrow(context))
|
imp.set_context(wrap.unsafe_cast_ref(), &from_glib_borrow(context))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -505,7 +524,7 @@ where
|
||||||
let clock = Option::<::Clock>::from_glib_borrow(clock);
|
let clock = Option::<::Clock>::from_glib_borrow(clock);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), false, {
|
||||||
imp.set_clock(&wrap, clock.as_ref().as_ref())
|
imp.set_clock(wrap.unsafe_cast_ref(), clock.as_ref().as_ref())
|
||||||
})
|
})
|
||||||
.to_glib()
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
@ -521,7 +540,7 @@ where
|
||||||
let wrap: Borrowed<Element> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Element> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
gst_panic_to_error!(&wrap, &instance.panicked(), None, {
|
gst_panic_to_error!(&wrap, &instance.panicked(), None, {
|
||||||
imp.provide_clock(&wrap)
|
imp.provide_clock(wrap.unsafe_cast_ref())
|
||||||
})
|
})
|
||||||
.to_glib_full()
|
.to_glib_full()
|
||||||
}
|
}
|
||||||
|
@ -539,7 +558,8 @@ where
|
||||||
|
|
||||||
// Can't catch panics here as posting the error message would cause
|
// Can't catch panics here as posting the error message would cause
|
||||||
// this code to be called again recursively forever.
|
// this code to be called again recursively forever.
|
||||||
imp.post_message(&wrap, from_glib_full(msg)).to_glib()
|
imp.post_message(wrap.unsafe_cast_ref(), from_glib_full(msg))
|
||||||
|
.to_glib()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -549,6 +569,8 @@ mod tests {
|
||||||
use glib::subclass;
|
use glib::subclass;
|
||||||
use std::sync::atomic;
|
use std::sync::atomic;
|
||||||
|
|
||||||
|
use ElementFactory;
|
||||||
|
|
||||||
pub mod imp {
|
pub mod imp {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
|
@ -563,34 +585,44 @@ mod tests {
|
||||||
fn sink_chain(
|
fn sink_chain(
|
||||||
&self,
|
&self,
|
||||||
_pad: &::Pad,
|
_pad: &::Pad,
|
||||||
_element: &::Element,
|
_element: &super::TestElement,
|
||||||
buffer: ::Buffer,
|
buffer: ::Buffer,
|
||||||
) -> Result<::FlowSuccess, ::FlowError> {
|
) -> Result<::FlowSuccess, ::FlowError> {
|
||||||
self.n_buffers.fetch_add(1, atomic::Ordering::SeqCst);
|
self.n_buffers.fetch_add(1, atomic::Ordering::SeqCst);
|
||||||
self.srcpad.push(buffer)
|
self.srcpad.push(buffer)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn sink_event(&self, _pad: &::Pad, _element: &::Element, event: ::Event) -> bool {
|
fn sink_event(
|
||||||
|
&self,
|
||||||
|
_pad: &::Pad,
|
||||||
|
_element: &super::TestElement,
|
||||||
|
event: ::Event,
|
||||||
|
) -> bool {
|
||||||
self.srcpad.push_event(event)
|
self.srcpad.push_event(event)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn sink_query(
|
fn sink_query(
|
||||||
&self,
|
&self,
|
||||||
_pad: &::Pad,
|
_pad: &::Pad,
|
||||||
_element: &::Element,
|
_element: &super::TestElement,
|
||||||
query: &mut ::QueryRef,
|
query: &mut ::QueryRef,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
self.srcpad.peer_query(query)
|
self.srcpad.peer_query(query)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn src_event(&self, _pad: &::Pad, _element: &::Element, event: ::Event) -> bool {
|
fn src_event(
|
||||||
|
&self,
|
||||||
|
_pad: &::Pad,
|
||||||
|
_element: &super::TestElement,
|
||||||
|
event: ::Event,
|
||||||
|
) -> bool {
|
||||||
self.sinkpad.push_event(event)
|
self.sinkpad.push_event(event)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn src_query(
|
fn src_query(
|
||||||
&self,
|
&self,
|
||||||
_pad: &::Pad,
|
_pad: &::Pad,
|
||||||
_element: &::Element,
|
_element: &super::TestElement,
|
||||||
query: &mut ::QueryRef,
|
query: &mut ::QueryRef,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
self.sinkpad.peer_query(query)
|
self.sinkpad.peer_query(query)
|
||||||
|
@ -600,13 +632,13 @@ mod tests {
|
||||||
impl ObjectSubclass for TestElement {
|
impl ObjectSubclass for TestElement {
|
||||||
const NAME: &'static str = "TestElement";
|
const NAME: &'static str = "TestElement";
|
||||||
type Type = super::TestElement;
|
type Type = super::TestElement;
|
||||||
type ParentType = ::Element;
|
type ParentType = Element;
|
||||||
type Instance = ::subclass::ElementInstanceStruct<Self>;
|
type Instance = ::subclass::ElementInstanceStruct<Self>;
|
||||||
type Class = subclass::simple::ClassStruct<Self>;
|
type Class = subclass::simple::ClassStruct<Self>;
|
||||||
|
|
||||||
glib_object_subclass!();
|
glib_object_subclass!();
|
||||||
|
|
||||||
fn with_class(klass: &subclass::simple::ClassStruct<Self>) -> Self {
|
fn with_class(klass: &Self::Class) -> Self {
|
||||||
let templ = klass.get_pad_template("sink").unwrap();
|
let templ = klass.get_pad_template("sink").unwrap();
|
||||||
let sinkpad = ::Pad::builder_with_template(&templ, Some("sink"))
|
let sinkpad = ::Pad::builder_with_template(&templ, Some("sink"))
|
||||||
.chain_function(|pad, parent, buffer| {
|
.chain_function(|pad, parent, buffer| {
|
||||||
|
@ -658,7 +690,7 @@ mod tests {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn class_init(klass: &mut subclass::simple::ClassStruct<Self>) {
|
fn class_init(klass: &mut Self::Class) {
|
||||||
klass.set_metadata(
|
klass.set_metadata(
|
||||||
"Test Element",
|
"Test Element",
|
||||||
"Generic",
|
"Generic",
|
||||||
|
@ -691,7 +723,7 @@ mod tests {
|
||||||
impl ElementImpl for TestElement {
|
impl ElementImpl for TestElement {
|
||||||
fn change_state(
|
fn change_state(
|
||||||
&self,
|
&self,
|
||||||
element: &::Element,
|
element: &Self::Type,
|
||||||
transition: ::StateChange,
|
transition: ::StateChange,
|
||||||
) -> Result<::StateChangeSuccess, ::StateChangeError> {
|
) -> Result<::StateChangeSuccess, ::StateChangeError> {
|
||||||
let res = self.parent_change_state(element, transition)?;
|
let res = self.parent_change_state(element, transition)?;
|
||||||
|
@ -706,7 +738,7 @@ mod tests {
|
||||||
}
|
}
|
||||||
|
|
||||||
glib_wrapper! {
|
glib_wrapper! {
|
||||||
pub struct TestElement(ObjectSubclass<imp::TestElement>) @extends ::Element, ::Object;
|
pub struct TestElement(ObjectSubclass<imp::TestElement>) @extends Element, ::Object;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe impl Send for TestElement {}
|
unsafe impl Send for TestElement {}
|
||||||
|
@ -735,15 +767,15 @@ mod tests {
|
||||||
);
|
);
|
||||||
|
|
||||||
let pipeline = ::Pipeline::new(None);
|
let pipeline = ::Pipeline::new(None);
|
||||||
let src = ::ElementFactory::make("fakesrc", None).unwrap();
|
let src = ElementFactory::make("fakesrc", None).unwrap();
|
||||||
let sink = ::ElementFactory::make("fakesink", None).unwrap();
|
let sink = ElementFactory::make("fakesink", None).unwrap();
|
||||||
|
|
||||||
src.set_property("num-buffers", &100i32).unwrap();
|
src.set_property("num-buffers", &100i32).unwrap();
|
||||||
|
|
||||||
pipeline
|
pipeline
|
||||||
.add_many(&[&src, &element.upcast_ref(), &sink])
|
.add_many(&[&src, &element.upcast_ref(), &sink])
|
||||||
.unwrap();
|
.unwrap();
|
||||||
::Element::link_many(&[&src, &element.upcast_ref(), &sink]).unwrap();
|
Element::link_many(&[&src, &element.upcast_ref(), &sink]).unwrap();
|
||||||
|
|
||||||
pipeline.set_state(::State::Playing).unwrap();
|
pipeline.set_state(::State::Playing).unwrap();
|
||||||
let bus = pipeline.get_bus().unwrap();
|
let bus = pipeline.get_bus().unwrap();
|
||||||
|
|
|
@ -9,49 +9,59 @@
|
||||||
use gst_sys;
|
use gst_sys;
|
||||||
|
|
||||||
use glib;
|
use glib;
|
||||||
use glib::translate::*;
|
use glib::prelude::*;
|
||||||
|
|
||||||
use glib::subclass::prelude::*;
|
use glib::subclass::prelude::*;
|
||||||
|
use glib::translate::*;
|
||||||
|
|
||||||
use Pad;
|
use Pad;
|
||||||
|
|
||||||
pub trait PadImpl: PadImplExt + ObjectImpl + Send + Sync {
|
pub trait PadImpl: PadImplExt + ObjectImpl + Send + Sync {
|
||||||
fn linked(&self, pad: &Pad, peer: &Pad) {
|
fn linked(&self, pad: &Self::Type, peer: &Pad) {
|
||||||
self.parent_linked(pad, peer)
|
self.parent_linked(pad, peer)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn unlinked(&self, pad: &Pad, peer: &Pad) {
|
fn unlinked(&self, pad: &Self::Type, peer: &Pad) {
|
||||||
self.parent_unlinked(pad, peer)
|
self.parent_unlinked(pad, peer)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait PadImplExt {
|
pub trait PadImplExt: ObjectSubclass {
|
||||||
fn parent_linked(&self, pad: &Pad, peer: &Pad);
|
fn parent_linked(&self, pad: &Self::Type, peer: &Pad);
|
||||||
|
|
||||||
fn parent_unlinked(&self, pad: &Pad, peer: &Pad);
|
fn parent_unlinked(&self, pad: &Self::Type, peer: &Pad);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: PadImpl> PadImplExt for T {
|
impl<T: PadImpl> PadImplExt for T {
|
||||||
fn parent_linked(&self, pad: &Pad, peer: &Pad) {
|
fn parent_linked(&self, pad: &Self::Type, peer: &Pad) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstPadClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstPadClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.linked
|
.linked
|
||||||
.map(|f| f(pad.to_glib_none().0, peer.to_glib_none().0))
|
.map(|f| {
|
||||||
|
f(
|
||||||
|
pad.unsafe_cast_ref::<Pad>().to_glib_none().0,
|
||||||
|
peer.to_glib_none().0,
|
||||||
|
)
|
||||||
|
})
|
||||||
.unwrap_or(())
|
.unwrap_or(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn parent_unlinked(&self, pad: &Pad, peer: &Pad) {
|
fn parent_unlinked(&self, pad: &Self::Type, peer: &Pad) {
|
||||||
unsafe {
|
unsafe {
|
||||||
let data = T::type_data();
|
let data = T::type_data();
|
||||||
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstPadClass;
|
let parent_class = data.as_ref().get_parent_class() as *mut gst_sys::GstPadClass;
|
||||||
|
|
||||||
(*parent_class)
|
(*parent_class)
|
||||||
.unlinked
|
.unlinked
|
||||||
.map(|f| f(pad.to_glib_none().0, peer.to_glib_none().0))
|
.map(|f| {
|
||||||
|
f(
|
||||||
|
pad.unsafe_cast_ref::<Pad>().to_glib_none().0,
|
||||||
|
peer.to_glib_none().0,
|
||||||
|
)
|
||||||
|
})
|
||||||
.unwrap_or(())
|
.unwrap_or(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,7 +81,7 @@ unsafe extern "C" fn pad_linked<T: PadImpl>(ptr: *mut gst_sys::GstPad, peer: *mu
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Pad> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Pad> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.linked(&wrap, &from_glib_borrow(peer))
|
imp.linked(wrap.unsafe_cast_ref(), &from_glib_borrow(peer))
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn pad_unlinked<T: PadImpl>(
|
unsafe extern "C" fn pad_unlinked<T: PadImpl>(
|
||||||
|
@ -82,7 +92,7 @@ unsafe extern "C" fn pad_unlinked<T: PadImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
let wrap: Borrowed<Pad> = from_glib_borrow(ptr);
|
let wrap: Borrowed<Pad> = from_glib_borrow(ptr);
|
||||||
|
|
||||||
imp.unlinked(&wrap, &from_glib_borrow(peer))
|
imp.unlinked(wrap.unsafe_cast_ref(), &from_glib_borrow(peer))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -93,6 +103,8 @@ mod tests {
|
||||||
use glib::subclass;
|
use glib::subclass;
|
||||||
use std::sync::atomic;
|
use std::sync::atomic;
|
||||||
|
|
||||||
|
use PadDirection;
|
||||||
|
|
||||||
pub mod imp {
|
pub mod imp {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
|
@ -104,7 +116,7 @@ mod tests {
|
||||||
impl ObjectSubclass for TestPad {
|
impl ObjectSubclass for TestPad {
|
||||||
const NAME: &'static str = "TestPad";
|
const NAME: &'static str = "TestPad";
|
||||||
type Type = super::TestPad;
|
type Type = super::TestPad;
|
||||||
type ParentType = ::Pad;
|
type ParentType = Pad;
|
||||||
type Instance = subclass::simple::InstanceStruct<Self>;
|
type Instance = subclass::simple::InstanceStruct<Self>;
|
||||||
type Class = subclass::simple::ClassStruct<Self>;
|
type Class = subclass::simple::ClassStruct<Self>;
|
||||||
|
|
||||||
|
@ -121,12 +133,12 @@ mod tests {
|
||||||
impl ObjectImpl for TestPad {}
|
impl ObjectImpl for TestPad {}
|
||||||
|
|
||||||
impl PadImpl for TestPad {
|
impl PadImpl for TestPad {
|
||||||
fn linked(&self, pad: &Pad, peer: &Pad) {
|
fn linked(&self, pad: &Self::Type, peer: &Pad) {
|
||||||
self.linked.store(true, atomic::Ordering::SeqCst);
|
self.linked.store(true, atomic::Ordering::SeqCst);
|
||||||
self.parent_linked(pad, peer)
|
self.parent_linked(pad, peer)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn unlinked(&self, pad: &Pad, peer: &Pad) {
|
fn unlinked(&self, pad: &Self::Type, peer: &Pad) {
|
||||||
self.unlinked.store(true, atomic::Ordering::SeqCst);
|
self.unlinked.store(true, atomic::Ordering::SeqCst);
|
||||||
self.parent_unlinked(pad, peer)
|
self.parent_unlinked(pad, peer)
|
||||||
}
|
}
|
||||||
|
@ -134,14 +146,14 @@ mod tests {
|
||||||
}
|
}
|
||||||
|
|
||||||
glib_wrapper! {
|
glib_wrapper! {
|
||||||
pub struct TestPad(ObjectSubclass<imp::TestPad>) @extends ::Pad, ::Object;
|
pub struct TestPad(ObjectSubclass<imp::TestPad>) @extends Pad, ::Object;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe impl Send for TestPad {}
|
unsafe impl Send for TestPad {}
|
||||||
unsafe impl Sync for TestPad {}
|
unsafe impl Sync for TestPad {}
|
||||||
|
|
||||||
impl TestPad {
|
impl TestPad {
|
||||||
pub fn new(name: &str, direction: ::PadDirection) -> Self {
|
pub fn new(name: &str, direction: PadDirection) -> Self {
|
||||||
glib::Object::new(
|
glib::Object::new(
|
||||||
TestPad::static_type(),
|
TestPad::static_type(),
|
||||||
&[("name", &name), ("direction", &direction)],
|
&[("name", &name), ("direction", &direction)],
|
||||||
|
@ -156,11 +168,11 @@ mod tests {
|
||||||
fn test_pad_subclass() {
|
fn test_pad_subclass() {
|
||||||
::init().unwrap();
|
::init().unwrap();
|
||||||
|
|
||||||
let pad = TestPad::new("test", ::PadDirection::Src);
|
let pad = TestPad::new("test", PadDirection::Src);
|
||||||
|
|
||||||
assert_eq!(pad.get_name(), "test");
|
assert_eq!(pad.get_name(), "test");
|
||||||
|
|
||||||
let otherpad = ::Pad::new(Some("other-test"), ::PadDirection::Sink);
|
let otherpad = Pad::new(Some("other-test"), PadDirection::Sink);
|
||||||
pad.link(&otherpad).unwrap();
|
pad.link(&otherpad).unwrap();
|
||||||
pad.unlink(&otherpad).unwrap();
|
pad.unlink(&otherpad).unwrap();
|
||||||
|
|
||||||
|
|
|
@ -21,8 +21,8 @@ use URIHandler;
|
||||||
use URIType;
|
use URIType;
|
||||||
|
|
||||||
pub trait URIHandlerImpl: super::element::ElementImpl {
|
pub trait URIHandlerImpl: super::element::ElementImpl {
|
||||||
fn get_uri(&self, element: &URIHandler) -> Option<String>;
|
fn get_uri(&self, element: &Self::Type) -> Option<String>;
|
||||||
fn set_uri(&self, element: &URIHandler, uri: &str) -> Result<(), glib::Error>;
|
fn set_uri(&self, element: &Self::Type, uri: &str) -> Result<(), glib::Error>;
|
||||||
fn get_uri_type() -> URIType;
|
fn get_uri_type() -> URIType;
|
||||||
fn get_protocols() -> Vec<String>;
|
fn get_protocols() -> Vec<String>;
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,8 @@ unsafe extern "C" fn uri_handler_get_uri<T: URIHandlerImpl>(
|
||||||
let instance = &*(uri_handler as *mut T::Instance);
|
let instance = &*(uri_handler as *mut T::Instance);
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
imp.get_uri(&from_glib_borrow(uri_handler)).to_glib_full()
|
imp.get_uri(&from_glib_borrow::<_, URIHandler>(uri_handler).unsafe_cast_ref())
|
||||||
|
.to_glib_full()
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe extern "C" fn uri_handler_set_uri<T: URIHandlerImpl>(
|
unsafe extern "C" fn uri_handler_set_uri<T: URIHandlerImpl>(
|
||||||
|
@ -84,7 +85,7 @@ unsafe extern "C" fn uri_handler_set_uri<T: URIHandlerImpl>(
|
||||||
let imp = instance.get_impl();
|
let imp = instance.get_impl();
|
||||||
|
|
||||||
match imp.set_uri(
|
match imp.set_uri(
|
||||||
&from_glib_borrow(uri_handler),
|
&from_glib_borrow::<_, URIHandler>(uri_handler).unsafe_cast_ref(),
|
||||||
glib::GString::from_glib_borrow(uri).as_str(),
|
glib::GString::from_glib_borrow(uri).as_str(),
|
||||||
) {
|
) {
|
||||||
Ok(()) => true.to_glib(),
|
Ok(()) => true.to_glib(),
|
||||||
|
|
Loading…
Reference in a new issue