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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
// 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 glib::object::IsA; use glib::translate::*; /// Tries to find what type of data is flowing from the given source [`gst::Pad`][crate::gst::Pad]. /// /// Free-function: gst_caps_unref /// ## `src` /// A source [`gst::Pad`][crate::gst::Pad] /// ## `size` /// The length in bytes /// /// # Returns /// /// the [`gst::Caps`][crate::gst::Caps] corresponding to the data /// stream. Returns [`None`] if no [`gst::Caps`][crate::gst::Caps] matches the data stream. #[doc(alias = "gst_type_find_helper")] pub fn type_find_helper<P: IsA<gst::Pad>>( src: &P, size: u64, ) -> Result<gst::Caps, glib::BoolError> { assert_initialized_main_thread!(); unsafe { Option::<_>::from_glib_full(ffi::gst_type_find_helper( src.as_ref().to_glib_none().0, size, )) .ok_or_else(|| glib::bool_error!("Could not find type")) } } /// Tries to find the best [`gst::Caps`][crate::gst::Caps] associated with `extension`. /// /// All available typefinders will be checked against the extension in order /// of rank. The caps of the first typefinder that can handle `extension` will be /// returned. /// /// Free-function: gst_caps_unref /// ## `obj` /// object doing the typefinding, or [`None`] (used for logging) /// ## `extension` /// an extension /// /// # Returns /// /// the [`gst::Caps`][crate::gst::Caps] corresponding to /// `extension`, or [`None`] if no type could be found. The caller should free /// the caps returned with `gst_caps_unref()`. #[doc(alias = "gst_type_find_helper_for_extension")] pub fn type_find_helper_for_extension<P: IsA<gst::Object>>( obj: Option<&P>, extension: &str, ) -> Result<gst::Caps, glib::BoolError> { assert_initialized_main_thread!(); unsafe { Option::<_>::from_glib_full(ffi::gst_type_find_helper_for_extension( obj.map(|p| p.as_ref()).to_glib_none().0, extension.to_glib_none().0, )) .ok_or_else(|| glib::bool_error!("Could not find type")) } } //#[doc(alias = "gst_type_find_helper_get_range")] //pub fn type_find_helper_get_range<P: IsA<gst::Object>, Q: IsA<gst::Object>, R: FnMut(&gst::Object, Option<&gst::Object>, u64, u32, &gst::Buffer) -> Result<gst::FlowSuccess, gst::FlowError>>(obj: &P, parent: Option<&Q>, func: R, size: u64, extension: Option<&str>) -> (Option<gst::Caps>, gst::TypeFindProbability) { // unsafe { TODO: call ffi:gst_type_find_helper_get_range() } //} //#[cfg(any(feature = "v1_14_3", feature = "dox"))] //#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_14_3")))] //#[doc(alias = "gst_type_find_helper_get_range_full")] //pub fn type_find_helper_get_range_full<P: IsA<gst::Object>, Q: IsA<gst::Object>, R: FnMut(&gst::Object, Option<&gst::Object>, u64, u32, &gst::Buffer) -> Result<gst::FlowSuccess, gst::FlowError>>(obj: &P, parent: Option<&Q>, func: R, size: u64, extension: Option<&str>) -> (Result<gst::FlowSuccess, gst::FlowError>, gst::Caps, gst::TypeFindProbability) { // unsafe { TODO: call ffi:gst_type_find_helper_get_range_full() } //}