1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
// 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 glib::object::IsA; use glib::translate::*; use gst_sys; use Object; use Pad; glib_wrapper! { /// /// /// # Implements /// /// [`ProxyPadExt`](trait.ProxyPadExt.html), [`PadExt`](trait.PadExt.html), [`GstObjectExt`](trait.GstObjectExt.html), [`glib::object::ObjectExt`](../glib/object/trait.ObjectExt.html), [`ProxyPadExtManual`](prelude/trait.ProxyPadExtManual.html), [`PadExtManual`](prelude/trait.PadExtManual.html) pub struct ProxyPad(Object<gst_sys::GstProxyPad, gst_sys::GstProxyPadClass, ProxyPadClass>) @extends Pad, Object; match fn { get_type => || gst_sys::gst_proxy_pad_get_type(), } } impl ProxyPad { //pub fn iterate_internal_links_default<P: IsA<Pad>, Q: IsA<Object>>(pad: &P, parent: Option<&Q>) -> /*Ignored*/Option<Iterator> { // unsafe { TODO: call gst_sys:gst_proxy_pad_iterate_internal_links_default() } //} } unsafe impl Send for ProxyPad {} unsafe impl Sync for ProxyPad {} pub const NONE_PROXY_PAD: Option<&ProxyPad> = None; /// Trait containing all `ProxyPad` methods. /// /// # Implementors /// /// [`GhostPad`](struct.GhostPad.html), [`ProxyPad`](struct.ProxyPad.html) pub trait ProxyPadExt: 'static { /// Get the internal pad of `self`. Unref target pad after usage. /// /// The internal pad of a `GhostPad` is the internally used /// pad of opposite direction, which is used to link to the target. /// /// # Returns /// /// the target `ProxyPad`, can /// be `None`. Unref target pad after usage. fn get_internal(&self) -> Option<ProxyPad>; } impl<O: IsA<ProxyPad>> ProxyPadExt for O { fn get_internal(&self) -> Option<ProxyPad> { unsafe { from_glib_full(gst_sys::gst_proxy_pad_get_internal( self.as_ref().to_glib_none().0, )) } } }