// 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 crate::{GLContext, GLDisplayType, GLWindow, GLAPI}; use glib::{ prelude::*, signal::{connect_raw, SignalHandlerId}, translate::*, }; use std::{boxed::Box as Box_, mem::transmute, ptr}; glib::wrapper! { #[doc(alias = "GstGLDisplay")] pub struct GLDisplay(Object) @extends gst::Object; match fn { type_ => || ffi::gst_gl_display_get_type(), } } impl GLDisplay { pub const NONE: Option<&'static GLDisplay> = None; #[doc(alias = "gst_gl_display_new")] pub fn new() -> GLDisplay { assert_initialized_main_thread!(); unsafe { from_glib_full(ffi::gst_gl_display_new()) } } #[cfg(any(feature = "v1_20", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_20")))] #[doc(alias = "gst_gl_display_new_with_type")] #[doc(alias = "new_with_type")] pub fn with_type(type_: GLDisplayType) -> Option { assert_initialized_main_thread!(); unsafe { from_glib_full(ffi::gst_gl_display_new_with_type(type_.into_glib())) } } } impl Default for GLDisplay { fn default() -> Self { Self::new() } } unsafe impl Send for GLDisplay {} unsafe impl Sync for GLDisplay {} pub trait GLDisplayExt: 'static { #[doc(alias = "gst_gl_display_add_context")] fn add_context(&self, context: &impl IsA) -> Result<(), glib::error::BoolError>; #[doc(alias = "gst_gl_display_create_context")] fn create_context( &self, other_context: Option<&impl IsA>, ) -> Result; #[doc(alias = "gst_gl_display_create_window")] fn create_window(&self) -> Result; #[doc(alias = "gst_gl_display_filter_gl_api")] fn filter_gl_api(&self, gl_api: GLAPI); #[doc(alias = "gst_gl_display_get_gl_api")] #[doc(alias = "get_gl_api")] fn gl_api(&self) -> GLAPI; #[doc(alias = "gst_gl_display_get_gl_api_unlocked")] #[doc(alias = "get_gl_api_unlocked")] fn gl_api_unlocked(&self) -> GLAPI; #[doc(alias = "gst_gl_display_get_handle_type")] #[doc(alias = "get_handle_type")] fn handle_type(&self) -> GLDisplayType; #[cfg(any(feature = "v1_18", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))] #[doc(alias = "gst_gl_display_remove_context")] fn remove_context(&self, context: &impl IsA); #[doc(alias = "gst_gl_display_remove_window")] fn remove_window(&self, window: &impl IsA) -> Result<(), glib::error::BoolError>; //#[cfg(any(feature = "v1_18", feature = "dox"))] //#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))] //#[doc(alias = "gst_gl_display_retrieve_window")] //fn retrieve_window(&self, data: /*Unimplemented*/Option, compare_func: /*Unimplemented*/FnMut(/*Unimplemented*/Option) -> i32) -> Option; #[doc(alias = "create-context")] fn connect_create_context< F: Fn(&Self, &GLContext) -> Option + Send + Sync + 'static, >( &self, f: F, ) -> SignalHandlerId; } impl> GLDisplayExt for O { fn add_context(&self, context: &impl IsA) -> Result<(), glib::error::BoolError> { unsafe { glib::result_from_gboolean!( ffi::gst_gl_display_add_context( self.as_ref().to_glib_none().0, context.as_ref().to_glib_none().0 ), "Failed to add OpenGL context" ) } } fn create_context( &self, other_context: Option<&impl IsA>, ) -> Result { unsafe { let mut p_context = ptr::null_mut(); let mut error = ptr::null_mut(); let is_ok = ffi::gst_gl_display_create_context( self.as_ref().to_glib_none().0, other_context.map(|p| p.as_ref()).to_glib_none().0, &mut p_context, &mut error, ); debug_assert_eq!(is_ok == glib::ffi::GFALSE, !error.is_null()); if error.is_null() { Ok(from_glib_full(p_context)) } else { Err(from_glib_full(error)) } } } fn create_window(&self) -> Result { unsafe { Option::<_>::from_glib_full(ffi::gst_gl_display_create_window( self.as_ref().to_glib_none().0, )) .ok_or_else(|| glib::bool_error!("Failed to create window")) } } fn filter_gl_api(&self, gl_api: GLAPI) { unsafe { ffi::gst_gl_display_filter_gl_api(self.as_ref().to_glib_none().0, gl_api.into_glib()); } } fn gl_api(&self) -> GLAPI { unsafe { from_glib(ffi::gst_gl_display_get_gl_api( self.as_ref().to_glib_none().0, )) } } fn gl_api_unlocked(&self) -> GLAPI { unsafe { from_glib(ffi::gst_gl_display_get_gl_api_unlocked( self.as_ref().to_glib_none().0, )) } } fn handle_type(&self) -> GLDisplayType { unsafe { from_glib(ffi::gst_gl_display_get_handle_type( self.as_ref().to_glib_none().0, )) } } #[cfg(any(feature = "v1_18", feature = "dox"))] #[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))] fn remove_context(&self, context: &impl IsA) { unsafe { ffi::gst_gl_display_remove_context( self.as_ref().to_glib_none().0, context.as_ref().to_glib_none().0, ); } } fn remove_window(&self, window: &impl IsA) -> Result<(), glib::error::BoolError> { unsafe { glib::result_from_gboolean!( ffi::gst_gl_display_remove_window( self.as_ref().to_glib_none().0, window.as_ref().to_glib_none().0 ), "Failed to remove window" ) } } //#[cfg(any(feature = "v1_18", feature = "dox"))] //#[cfg_attr(feature = "dox", doc(cfg(feature = "v1_18")))] //fn retrieve_window(&self, data: /*Unimplemented*/Option, compare_func: /*Unimplemented*/FnMut(/*Unimplemented*/Option) -> i32) -> Option { // unsafe { TODO: call ffi:gst_gl_display_retrieve_window() } //} fn connect_create_context< F: Fn(&Self, &GLContext) -> Option + Send + Sync + 'static, >( &self, f: F, ) -> SignalHandlerId { unsafe extern "C" fn create_context_trampoline< P: IsA, F: Fn(&P, &GLContext) -> Option + Send + Sync + 'static, >( this: *mut ffi::GstGLDisplay, context: *mut ffi::GstGLContext, f: glib::ffi::gpointer, ) -> *mut ffi::GstGLContext { let f: &F = &*(f as *const F); f( GLDisplay::from_glib_borrow(this).unsafe_cast_ref(), &from_glib_borrow(context), ) .to_glib_full() } unsafe { let f: Box_ = Box_::new(f); connect_raw( self.as_ptr() as *mut _, b"create-context\0".as_ptr() as *const _, Some(transmute::<_, unsafe extern "C" fn()>( create_context_trampoline:: as *const (), )), Box_::into_raw(f), ) } } }