// 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 ges_sys; use glib; use glib::object::Cast; use glib::object::IsA; use glib::signal::connect_raw; use glib::signal::SignalHandlerId; use glib::translate::*; use glib_sys; use gst; use std::boxed::Box as Box_; use std::mem::transmute; use Asset; use Clip; use Extractable; use Timeline; use Track; use TrackType; glib_wrapper! { pub struct Layer(Object) @implements Extractable; match fn { get_type => || ges_sys::ges_layer_get_type(), } } impl Layer { pub fn new() -> Layer { assert_initialized_main_thread!(); unsafe { from_glib_none(ges_sys::ges_layer_new()) } } } impl Default for Layer { fn default() -> Self { Self::new() } } pub const NONE_LAYER: Option<&Layer> = None; pub trait LayerExt: 'static { fn add_asset>( &self, asset: &P, start: gst::ClockTime, inpoint: gst::ClockTime, duration: gst::ClockTime, track_types: TrackType, ) -> Result; fn add_clip>(&self, clip: &P) -> Result<(), glib::error::BoolError>; fn get_active_for_track>(&self, track: &P) -> bool; fn get_auto_transition(&self) -> bool; fn get_clips(&self) -> Vec; fn get_clips_in_interval(&self, start: gst::ClockTime, end: gst::ClockTime) -> Vec; fn get_duration(&self) -> gst::ClockTime; fn get_priority(&self) -> u32; fn get_timeline(&self) -> Option; fn is_empty(&self) -> bool; fn remove_clip>(&self, clip: &P) -> Result<(), glib::error::BoolError>; fn set_active_for_tracks(&self, active: bool, tracks: &[Track]) -> bool; fn set_auto_transition(&self, auto_transition: bool); #[cfg_attr(feature = "v1_16", deprecated)] fn set_priority(&self, priority: u32); fn set_timeline>(&self, timeline: &P); //fn connect_active_changed(&self, f: F) -> SignalHandlerId; fn connect_clip_added(&self, f: F) -> SignalHandlerId; fn connect_clip_removed(&self, f: F) -> SignalHandlerId; fn connect_property_auto_transition_notify( &self, f: F, ) -> SignalHandlerId; #[cfg_attr(feature = "v1_16", deprecated)] fn connect_property_priority_notify(&self, f: F) -> SignalHandlerId; } impl> LayerExt for O { fn add_asset>( &self, asset: &P, start: gst::ClockTime, inpoint: gst::ClockTime, duration: gst::ClockTime, track_types: TrackType, ) -> Result { unsafe { Option::<_>::from_glib_none(ges_sys::ges_layer_add_asset( self.as_ref().to_glib_none().0, asset.as_ref().to_glib_none().0, start.to_glib(), inpoint.to_glib(), duration.to_glib(), track_types.to_glib(), )) .ok_or_else(|| glib_bool_error!("Failed to add asset")) } } fn add_clip>(&self, clip: &P) -> Result<(), glib::error::BoolError> { unsafe { glib_result_from_gboolean!( ges_sys::ges_layer_add_clip( self.as_ref().to_glib_none().0, clip.as_ref().to_glib_none().0 ), "Failed to add clip" ) } } fn get_active_for_track>(&self, track: &P) -> bool { unsafe { from_glib(ges_sys::ges_layer_get_active_for_track( self.as_ref().to_glib_none().0, track.as_ref().to_glib_none().0, )) } } fn get_auto_transition(&self) -> bool { unsafe { from_glib(ges_sys::ges_layer_get_auto_transition( self.as_ref().to_glib_none().0, )) } } fn get_clips(&self) -> Vec { unsafe { FromGlibPtrContainer::from_glib_full(ges_sys::ges_layer_get_clips( self.as_ref().to_glib_none().0, )) } } fn get_clips_in_interval(&self, start: gst::ClockTime, end: gst::ClockTime) -> Vec { unsafe { FromGlibPtrContainer::from_glib_full(ges_sys::ges_layer_get_clips_in_interval( self.as_ref().to_glib_none().0, start.to_glib(), end.to_glib(), )) } } fn get_duration(&self) -> gst::ClockTime { unsafe { from_glib(ges_sys::ges_layer_get_duration( self.as_ref().to_glib_none().0, )) } } fn get_priority(&self) -> u32 { unsafe { ges_sys::ges_layer_get_priority(self.as_ref().to_glib_none().0) } } fn get_timeline(&self) -> Option { unsafe { from_glib_none(ges_sys::ges_layer_get_timeline( self.as_ref().to_glib_none().0, )) } } fn is_empty(&self) -> bool { unsafe { from_glib(ges_sys::ges_layer_is_empty(self.as_ref().to_glib_none().0)) } } fn remove_clip>(&self, clip: &P) -> Result<(), glib::error::BoolError> { unsafe { glib_result_from_gboolean!( ges_sys::ges_layer_remove_clip( self.as_ref().to_glib_none().0, clip.as_ref().to_glib_none().0 ), "Failed to remove clip" ) } } fn set_active_for_tracks(&self, active: bool, tracks: &[Track]) -> bool { unsafe { from_glib(ges_sys::ges_layer_set_active_for_tracks( self.as_ref().to_glib_none().0, active.to_glib(), tracks.to_glib_none().0, )) } } fn set_auto_transition(&self, auto_transition: bool) { unsafe { ges_sys::ges_layer_set_auto_transition( self.as_ref().to_glib_none().0, auto_transition.to_glib(), ); } } fn set_priority(&self, priority: u32) { unsafe { ges_sys::ges_layer_set_priority(self.as_ref().to_glib_none().0, priority); } } fn set_timeline>(&self, timeline: &P) { unsafe { ges_sys::ges_layer_set_timeline( self.as_ref().to_glib_none().0, timeline.as_ref().to_glib_none().0, ); } } //fn connect_active_changed(&self, f: F) -> SignalHandlerId { // Empty ctype tracks: *.PtrArray TypeId { ns_id: 1, id: 17 } //} fn connect_clip_added(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn clip_added_trampoline( this: *mut ges_sys::GESLayer, clip: *mut ges_sys::GESClip, f: glib_sys::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f( &Layer::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(clip), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"clip-added\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( clip_added_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_clip_removed(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn clip_removed_trampoline( this: *mut ges_sys::GESLayer, clip: *mut ges_sys::GESClip, f: glib_sys::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f( &Layer::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(clip), ) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"clip-removed\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( clip_removed_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_property_auto_transition_notify( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn notify_auto_transition_trampoline( this: *mut ges_sys::GESLayer, _param_spec: glib_sys::gpointer, f: glib_sys::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f(&Layer::from_glib_borrow(this).unsafe_cast_ref()) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::auto-transition\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_auto_transition_trampoline:: as *const (), )), Box_::into_raw(f), ) } } fn connect_property_priority_notify(&self, f: F) -> SignalHandlerId { unsafe extern "C" fn notify_priority_trampoline( this: *mut ges_sys::GESLayer, _param_spec: glib_sys::gpointer, f: glib_sys::gpointer, ) where P: IsA, { let f: &F = &*(f as *const F); f(&Layer::from_glib_borrow(this).unsafe_cast_ref()) } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"notify::priority\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( notify_priority_trampoline:: as *const (), )), Box_::into_raw(f), ) } } }