// 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 Bin; use ChildProxy; use Clock; use ClockTime; use Element; use Object; use ffi; use glib::object::Cast; use glib::object::IsA; use glib::signal::SignalHandlerId; use glib::signal::connect_raw; use glib::translate::*; use glib_ffi; use std::boxed::Box as Box_; use std::mem::transmute; glib_wrapper! { pub struct Pipeline(Object) @extends Bin, Element, Object, @implements ChildProxy; match fn { get_type => || ffi::gst_pipeline_get_type(), } } impl Pipeline { pub fn new<'a, P: Into>>(name: P) -> Pipeline { assert_initialized_main_thread!(); let name = name.into(); unsafe { Element::from_glib_none(ffi::gst_pipeline_new(name.to_glib_none().0)).unsafe_cast() } } } unsafe impl Send for Pipeline {} unsafe impl Sync for Pipeline {} pub const NONE_PIPELINE: Option<&Pipeline> = None; pub trait PipelineExt: 'static { fn auto_clock(&self); fn get_auto_flush_bus(&self) -> bool; fn get_delay(&self) -> ClockTime; fn get_latency(&self) -> ClockTime; fn get_pipeline_clock(&self) -> Option; fn set_auto_flush_bus(&self, auto_flush: bool); fn set_delay(&self, delay: ClockTime); fn set_latency(&self, latency: ClockTime); fn use_clock<'a, P: IsA + 'a, Q: Into>>(&self, clock: Q); fn connect_property_auto_flush_bus_notify(&self, f: F) -> SignalHandlerId; fn connect_property_delay_notify(&self, f: F) -> SignalHandlerId; fn connect_property_latency_notify(&self, f: F) -> SignalHandlerId; } impl> PipelineExt for O { fn auto_clock(&self) { unsafe { ffi::gst_pipeline_auto_clock(self.as_ref().to_glib_none().0); } } fn get_auto_flush_bus(&self) -> bool { unsafe { from_glib(ffi::gst_pipeline_get_auto_flush_bus(self.as_ref().to_glib_none().0)) } } fn get_delay(&self) -> ClockTime { unsafe { from_glib(ffi::gst_pipeline_get_delay(self.as_ref().to_glib_none().0)) } } fn get_latency(&self) -> ClockTime { unsafe { from_glib(ffi::gst_pipeline_get_latency(self.as_ref().to_glib_none().0)) } } fn get_pipeline_clock(&self) -> Option { unsafe { from_glib_full(ffi::gst_pipeline_get_pipeline_clock(self.as_ref().to_glib_none().0)) } } fn set_auto_flush_bus(&self, auto_flush: bool) { unsafe { ffi::gst_pipeline_set_auto_flush_bus(self.as_ref().to_glib_none().0, auto_flush.to_glib()); } } fn set_delay(&self, delay: ClockTime) { unsafe { ffi::gst_pipeline_set_delay(self.as_ref().to_glib_none().0, delay.to_glib()); } } fn set_latency(&self, latency: ClockTime) { unsafe { ffi::gst_pipeline_set_latency(self.as_ref().to_glib_none().0, latency.to_glib()); } } fn use_clock<'a, P: IsA + 'a, Q: Into>>(&self, clock: Q) { let clock = clock.into(); unsafe { ffi::gst_pipeline_use_clock(self.as_ref().to_glib_none().0, clock.map(|p| p.as_ref()).to_glib_none().0); } } fn connect_property_auto_flush_bus_notify(&self, f: F) -> SignalHandlerId { unsafe { let f: Box_ = Box_::new(f); connect_raw(self.as_ptr() as *mut _, b"notify::auto-flush-bus\0".as_ptr() as *const _, Some(transmute(notify_auto_flush_bus_trampoline:: as usize)), Box_::into_raw(f)) } } fn connect_property_delay_notify(&self, f: F) -> SignalHandlerId { unsafe { let f: Box_ = Box_::new(f); connect_raw(self.as_ptr() as *mut _, b"notify::delay\0".as_ptr() as *const _, Some(transmute(notify_delay_trampoline:: as usize)), Box_::into_raw(f)) } } fn connect_property_latency_notify(&self, f: F) -> SignalHandlerId { unsafe { let f: Box_ = Box_::new(f); connect_raw(self.as_ptr() as *mut _, b"notify::latency\0".as_ptr() as *const _, Some(transmute(notify_latency_trampoline:: as usize)), Box_::into_raw(f)) } } } unsafe extern "C" fn notify_auto_flush_bus_trampoline(this: *mut ffi::GstPipeline, _param_spec: glib_ffi::gpointer, f: glib_ffi::gpointer) where P: IsA { let f: &F = transmute(f); f(&Pipeline::from_glib_borrow(this).unsafe_cast()) } unsafe extern "C" fn notify_delay_trampoline(this: *mut ffi::GstPipeline, _param_spec: glib_ffi::gpointer, f: glib_ffi::gpointer) where P: IsA { let f: &F = transmute(f); f(&Pipeline::from_glib_borrow(this).unsafe_cast()) } unsafe extern "C" fn notify_latency_trampoline(this: *mut ffi::GstPipeline, _param_spec: glib_ffi::gpointer, f: glib_ffi::gpointer) where P: IsA { let f: &F = transmute(f); f(&Pipeline::from_glib_borrow(this).unsafe_cast()) }