// This file was generated by gir (https://github.com/gtk-rs/gir) // from gir-files (https://github.com/gtk-rs/gir-files) // DO NOT EDIT use crate::Caps; use crate::Object; use crate::Pad; use crate::PadDirection; use crate::PadPresence; use glib::object::IsA; use glib::object::ObjectType as ObjectType_; use glib::signal::connect_raw; use glib::signal::SignalHandlerId; use glib::translate::*; use glib::StaticType; use glib::Value; use std::boxed::Box as Box_; use std::mem::transmute; glib::glib_wrapper! { pub struct PadTemplate(Object) @extends Object; match fn { get_type => || ffi::gst_pad_template_get_type(), } } impl PadTemplate { pub fn new( name_template: &str, direction: PadDirection, presence: PadPresence, caps: &Caps, ) -> Result { assert_initialized_main_thread!(); unsafe { Option::<_>::from_glib_none(ffi::gst_pad_template_new( name_template.to_glib_none().0, direction.to_glib(), presence.to_glib(), caps.to_glib_none().0, )) .ok_or_else(|| glib::glib_bool_error!("Failed to create pad template")) } } #[cfg(any(feature = "v1_14", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_14")))] pub fn with_gtype( name_template: &str, direction: PadDirection, presence: PadPresence, caps: &Caps, pad_type: glib::types::Type, ) -> Result { assert_initialized_main_thread!(); unsafe { Option::<_>::from_glib_none(ffi::gst_pad_template_new_with_gtype( name_template.to_glib_none().0, direction.to_glib(), presence.to_glib(), caps.to_glib_none().0, pad_type.to_glib(), )) .ok_or_else(|| glib::glib_bool_error!("Failed to create pad template")) } } pub fn get_caps(&self) -> Option { unsafe { from_glib_full(ffi::gst_pad_template_get_caps(self.to_glib_none().0)) } } #[cfg(any(feature = "v1_18", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_18")))] pub fn get_documentation_caps(&self) -> Option { unsafe { from_glib_full(ffi::gst_pad_template_get_documentation_caps( self.to_glib_none().0, )) } } pub fn pad_created>(&self, pad: &P) { unsafe { ffi::gst_pad_template_pad_created(self.to_glib_none().0, pad.as_ref().to_glib_none().0); } } #[cfg(any(feature = "v1_18", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_18")))] pub fn set_documentation_caps(&self, caps: &Caps) { unsafe { ffi::gst_pad_template_set_documentation_caps( self.to_glib_none().0, caps.to_glib_none().0, ); } } pub fn get_property_direction(&self) -> PadDirection { unsafe { let mut value = Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"direction\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `direction` getter") .unwrap() } } #[cfg(any(feature = "v1_14", all(not(doctest), doc)))] #[cfg_attr(all(not(doctest), doc), doc(cfg(feature = "v1_14")))] pub fn get_property_gtype(&self) -> glib::types::Type { unsafe { let mut value = Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"gtype\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `gtype` getter") .unwrap() } } pub fn get_property_name_template(&self) -> Option { unsafe { let mut value = Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"name-template\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `name-template` getter") } } pub fn get_property_presence(&self) -> PadPresence { unsafe { let mut value = Value::from_type(::static_type()); glib::gobject_ffi::g_object_get_property( self.as_ptr() as *mut glib::gobject_ffi::GObject, b"presence\0".as_ptr() as *const _, value.to_glib_none_mut().0, ); value .get() .expect("Return Value for property `presence` getter") .unwrap() } } pub fn connect_pad_created( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn pad_created_trampoline< F: Fn(&PadTemplate, &Pad) + Send + Sync + 'static, >( this: *mut ffi::GstPadTemplate, pad: *mut ffi::GstPad, f: glib::ffi::gpointer, ) { let f: &F = &*(f as *const F); f(&from_glib_borrow(this), &from_glib_borrow(pad)) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"pad-created\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( pad_created_trampoline:: as *const (), )), Box_::into_raw(f), ) } } } unsafe impl Send for PadTemplate {} unsafe impl Sync for PadTemplate {}