// This file was generated by gir (https://github.com/gtk-rs/gir) // from gir-files (https://github.com/gtk-rs/gir-files) // from gst-gir-files (https://gitlab.freedesktop.org/gstreamer/gir-files-rs.git) // DO NOT EDIT use crate::ChildProxy; use crate::Element; #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] use crate::ElementFlags; use crate::Object; use crate::Pad; use crate::PadDirection; use glib::object::Cast; use glib::object::IsA; use glib::signal::connect_raw; use glib::signal::SignalHandlerId; use glib::translate::*; use glib::StaticType; use glib::ToValue; use std::boxed::Box as Box_; use std::mem::transmute; glib::wrapper! { pub struct Bin(Object) @extends Element, Object, @implements ChildProxy; match fn { type_ => || ffi::gst_bin_get_type(), } } impl Bin { #[doc(alias = "gst_bin_new")] pub fn new(name: Option<&str>) -> Bin { assert_initialized_main_thread!(); unsafe { Element::from_glib_none(ffi::gst_bin_new(name.to_glib_none().0)).unsafe_cast() } } } unsafe impl Send for Bin {} unsafe impl Sync for Bin {} pub const NONE_BIN: Option<&Bin> = None; pub trait GstBinExt: 'static { #[doc(alias = "gst_bin_add")] fn add>(&self, element: &P) -> Result<(), glib::error::BoolError>; //#[doc(alias = "gst_bin_add_many")] //fn add_many>(&self, element_1: &P, : /*Unknown conversion*//*Unimplemented*/Fundamental: VarArgs); #[doc(alias = "gst_bin_find_unlinked_pad")] fn find_unlinked_pad(&self, direction: PadDirection) -> Option; #[doc(alias = "gst_bin_get_by_interface")] fn by_interface(&self, iface: glib::types::Type) -> Option; #[doc(alias = "gst_bin_get_by_name")] fn by_name(&self, name: &str) -> Option; #[doc(alias = "gst_bin_get_by_name_recurse_up")] fn by_name_recurse_up(&self, name: &str) -> Option; #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] #[doc(alias = "gst_bin_get_suppressed_flags")] fn suppressed_flags(&self) -> ElementFlags; //#[cfg(any(feature = "v1_18", feature = "dox"))] //#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))] //#[doc(alias = "gst_bin_iterate_all_by_element_factory_name")] //fn iterate_all_by_element_factory_name(&self, factory_name: &str) -> /*Ignored*/Option; //#[doc(alias = "gst_bin_iterate_all_by_interface")] //fn iterate_all_by_interface(&self, iface: glib::types::Type) -> /*Ignored*/Option; //#[doc(alias = "gst_bin_iterate_elements")] //fn iterate_elements(&self) -> /*Ignored*/Option; //#[doc(alias = "gst_bin_iterate_recurse")] //fn iterate_recurse(&self) -> /*Ignored*/Option; //#[doc(alias = "gst_bin_iterate_sinks")] //fn iterate_sinks(&self) -> /*Ignored*/Option; //#[doc(alias = "gst_bin_iterate_sorted")] //fn iterate_sorted(&self) -> /*Ignored*/Option; //#[doc(alias = "gst_bin_iterate_sources")] //fn iterate_sources(&self) -> /*Ignored*/Option; #[doc(alias = "gst_bin_recalculate_latency")] fn recalculate_latency(&self) -> Result<(), glib::error::BoolError>; #[doc(alias = "gst_bin_remove")] fn remove>(&self, element: &P) -> Result<(), glib::error::BoolError>; //#[doc(alias = "gst_bin_remove_many")] //fn remove_many>(&self, element_1: &P, : /*Unknown conversion*//*Unimplemented*/Fundamental: VarArgs); #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] #[doc(alias = "gst_bin_set_suppressed_flags")] fn set_suppressed_flags(&self, flags: ElementFlags); #[doc(alias = "gst_bin_sync_children_states")] fn sync_children_states(&self) -> Result<(), glib::error::BoolError>; #[doc(alias = "get_property_async_handling")] fn is_async_handling(&self) -> bool; #[doc(alias = "set_property_async_handling")] fn set_async_handling(&self, async_handling: bool); #[doc(alias = "get_property_message_forward")] fn is_message_forward(&self) -> bool; #[doc(alias = "set_property_message_forward")] fn set_message_forward(&self, message_forward: bool); #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] fn connect_deep_element_added( &self, f: F, ) -> SignalHandlerId; #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] fn connect_deep_element_removed( &self, f: F, ) -> SignalHandlerId; fn connect_element_added( &self, f: F, ) -> SignalHandlerId; fn connect_element_removed( &self, f: F, ) -> SignalHandlerId; fn connect_property_async_handling_notify( &self, f: F, ) -> SignalHandlerId; fn connect_property_message_forward_notify( &self, f: F, ) -> SignalHandlerId; } impl> GstBinExt for O { fn add>(&self, element: &P) -> Result<(), glib::error::BoolError> { unsafe { glib::result_from_gboolean!( ffi::gst_bin_add( self.as_ref().to_glib_none().0, element.as_ref().to_glib_none().0 ), "Failed to add element" ) } } //fn add_many>(&self, element_1: &P, : /*Unknown conversion*//*Unimplemented*/Fundamental: VarArgs) { // unsafe { TODO: call ffi:gst_bin_add_many() } //} fn find_unlinked_pad(&self, direction: PadDirection) -> Option { unsafe { from_glib_full(ffi::gst_bin_find_unlinked_pad( self.as_ref().to_glib_none().0, direction.to_glib(), )) } } fn by_interface(&self, iface: glib::types::Type) -> Option { unsafe { from_glib_full(ffi::gst_bin_get_by_interface( self.as_ref().to_glib_none().0, iface.to_glib(), )) } } fn by_name(&self, name: &str) -> Option { unsafe { from_glib_full(ffi::gst_bin_get_by_name( self.as_ref().to_glib_none().0, name.to_glib_none().0, )) } } fn by_name_recurse_up(&self, name: &str) -> Option { unsafe { from_glib_full(ffi::gst_bin_get_by_name_recurse_up( self.as_ref().to_glib_none().0, name.to_glib_none().0, )) } } #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] fn suppressed_flags(&self) -> ElementFlags { unsafe { from_glib(ffi::gst_bin_get_suppressed_flags( self.as_ref().to_glib_none().0, )) } } //#[cfg(any(feature = "v1_18", feature = "dox"))] //#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))] //fn iterate_all_by_element_factory_name(&self, factory_name: &str) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_all_by_element_factory_name() } //} //fn iterate_all_by_interface(&self, iface: glib::types::Type) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_all_by_interface() } //} //fn iterate_elements(&self) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_elements() } //} //fn iterate_recurse(&self) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_recurse() } //} //fn iterate_sinks(&self) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_sinks() } //} //fn iterate_sorted(&self) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_sorted() } //} //fn iterate_sources(&self) -> /*Ignored*/Option { // unsafe { TODO: call ffi:gst_bin_iterate_sources() } //} fn recalculate_latency(&self) -> Result<(), glib::error::BoolError> { unsafe { glib::result_from_gboolean!( ffi::gst_bin_recalculate_latency(self.as_ref().to_glib_none().0), "Failed to recalculate latency" ) } } fn remove>(&self, element: &P) -> Result<(), glib::error::BoolError> { unsafe { glib::result_from_gboolean!( ffi::gst_bin_remove( self.as_ref().to_glib_none().0, element.as_ref().to_glib_none().0 ), "Failed to remove element" ) } } //fn remove_many>(&self, element_1: &P, : /*Unknown conversion*//*Unimplemented*/Fundamental: VarArgs) { // unsafe { TODO: call ffi:gst_bin_remove_many() } //} #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] fn set_suppressed_flags(&self, flags: ElementFlags) { unsafe { ffi::gst_bin_set_suppressed_flags(self.as_ref().to_glib_none().0, flags.to_glib()); } } fn sync_children_states(&self) -> Result<(), glib::error::BoolError> { unsafe { glib::result_from_gboolean!( ffi::gst_bin_sync_children_states(self.as_ref().to_glib_none().0), "Failed to sync children states" ) } } fn is_async_handling(&self) -> bool { unsafe { let mut value = glib::Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.to_glib_none().0 as *mut glib::gobject_ffi::GObject, b"async-handling\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `async-handling` getter") } } fn set_async_handling(&self, async_handling: bool) { unsafe { glib::gobject_ffi::g_object_set_property( self.to_glib_none().0 as *mut glib::gobject_ffi::GObject, b"async-handling\0".as_ptr() as *const _, async_handling.to_value().to_glib_none().0, ); } } fn is_message_forward(&self) -> bool { unsafe { let mut value = glib::Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.to_glib_none().0 as *mut glib::gobject_ffi::GObject, b"message-forward\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `message-forward` getter") } } fn set_message_forward(&self, message_forward: bool) { unsafe { glib::gobject_ffi::g_object_set_property( self.to_glib_none().0 as *mut glib::gobject_ffi::GObject, b"message-forward\0".as_ptr() as *const _, message_forward.to_value().to_glib_none().0, ); } } #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] fn connect_deep_element_added( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn deep_element_added_trampoline< P, F: Fn(&P, &Bin, &Element) + Send + Sync + 'static, >( this: *mut ffi::GstBin, sub_bin: *mut ffi::GstBin, element: *mut ffi::GstElement, f: glib::ffi::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f( &Bin::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(sub_bin), &from_glib_borrow(element), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"deep-element-added\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( deep_element_added_trampoline:: as *const (), )), Box_::into_raw(f), ) } } #[cfg(any(feature = "v1_10", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_10")))] fn connect_deep_element_removed( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn deep_element_removed_trampoline< P, F: Fn(&P, &Bin, &Element) + Send + Sync + 'static, >( this: *mut ffi::GstBin, sub_bin: *mut ffi::GstBin, element: *mut ffi::GstElement, f: glib::ffi::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f( &Bin::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(sub_bin), &from_glib_borrow(element), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"deep-element-removed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( deep_element_removed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_element_added( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn element_added_trampoline< P, F: Fn(&P, &Element) + Send + Sync + 'static, >( this: *mut ffi::GstBin, element: *mut ffi::GstElement, f: glib::ffi::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f( &Bin::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(element), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"element-added\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( element_added_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_element_removed( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn element_removed_trampoline< P, F: Fn(&P, &Element) + Send + Sync + 'static, >( this: *mut ffi::GstBin, element: *mut ffi::GstElement, f: glib::ffi::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f( &Bin::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(element), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"element-removed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( element_removed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_property_async_handling_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_async_handling_trampoline< P, F: Fn(&P) + Send + Sync + 'static, >( this: *mut ffi::GstBin, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f(&Bin::from_glib_borrow(this).unsafe_cast_ref()) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::async-handling\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_async_handling_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_property_message_forward_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_message_forward_trampoline< P, F: Fn(&P) + Send + Sync + 'static, >( this: *mut ffi::GstBin, _param_spec: glib::ffi::gpointer, f: glib::ffi::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f(&Bin::from_glib_borrow(this).unsafe_cast_ref()) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::message-forward\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_message_forward_trampoline:: as *const (), )), Box_::into_raw(f), ) } } }