gstreamer_gl/subclass/
gl_base_src.rs
1use ffi::{GstGLBaseSrc, GstGLMemory};
2use glib::translate::*;
3use gst::{result_from_gboolean, LoggableError, CAT_RUST};
4use gst_base::subclass::prelude::*;
5
6use crate::{ffi, prelude::*, GLBaseSrc, GLMemory, GLAPI};
7
8pub trait GLBaseSrcImpl: PushSrcImpl + ObjectSubclass<Type: IsA<GLBaseSrc>> {
9 const SUPPORTED_GL_API: GLAPI;
10
11 fn gl_start(&self) -> Result<(), LoggableError> {
13 self.parent_gl_start()
14 }
15
16 fn gl_stop(&self) {
18 self.parent_gl_stop()
19 }
20
21 fn fill_gl_memory(&self, memory: &GLMemory) -> Result<(), LoggableError> {
23 self.parent_fill_gl_memory(memory)
24 }
25}
26
27pub trait GLBaseSrcImplExt: GLBaseSrcImpl {
28 fn parent_gl_start(&self) -> Result<(), LoggableError> {
29 unsafe {
30 let data = Self::type_data();
31 let parent_class = data.as_ref().parent_class() as *mut ffi::GstGLBaseSrcClass;
32
33 (*parent_class)
34 .gl_start
35 .map(|f| {
36 result_from_gboolean!(
37 f(self.obj().unsafe_cast_ref::<GLBaseSrc>().to_glib_none().0),
38 CAT_RUST,
39 "Parent function `gl_start` failed",
40 )
41 })
42 .unwrap_or(Ok(()))
43 }
44 }
45
46 fn parent_gl_stop(&self) {
47 unsafe {
48 let data = Self::type_data();
49 let parent_class = data.as_ref().parent_class() as *mut ffi::GstGLBaseSrcClass;
50
51 if let Some(f) = (*parent_class).gl_stop {
52 f(self.obj().unsafe_cast_ref::<GLBaseSrc>().to_glib_none().0)
53 }
54 }
55 }
56
57 fn parent_fill_gl_memory(&self, memory: &GLMemory) -> Result<(), LoggableError> {
58 unsafe {
59 let data = Self::type_data();
60 let parent_class = data.as_ref().parent_class() as *mut ffi::GstGLBaseSrcClass;
61
62 (*parent_class)
63 .fill_gl_memory
64 .map(|f| {
65 result_from_gboolean!(
66 f(
67 self.obj().unsafe_cast_ref::<GLBaseSrc>().to_glib_none().0,
68 mut_override(memory.to_glib_none().0),
69 ),
70 CAT_RUST,
71 "Parent function `fill_gl_memory` failed",
72 )
73 })
74 .unwrap_or(Ok(()))
75 }
76 }
77}
78
79impl<T: GLBaseSrcImpl> GLBaseSrcImplExt for T {}
80
81unsafe impl<T: GLBaseSrcImpl> IsSubclassable<T> for GLBaseSrc {
82 fn class_init(klass: &mut glib::Class<Self>) {
83 Self::parent_class_init::<T>(klass);
84 let klass = klass.as_mut();
85 klass.supported_gl_api = T::SUPPORTED_GL_API.into_glib();
86 klass.gl_start = Some(gl_start::<T>);
87 klass.gl_stop = Some(gl_stop::<T>);
88 klass.fill_gl_memory = Some(fill_gl_memory::<T>);
89 }
90}
91
92unsafe extern "C" fn gl_start<T: GLBaseSrcImpl>(ptr: *mut GstGLBaseSrc) -> glib::ffi::gboolean {
93 let instance = &*(ptr as *mut T::Instance);
94 let imp = instance.imp();
95
96 gst::panic_to_error!(imp, false, {
97 match imp.gl_start() {
98 Ok(()) => true,
99 Err(err) => {
100 err.log_with_imp(imp);
101 false
102 }
103 }
104 })
105 .into_glib()
106}
107
108unsafe extern "C" fn gl_stop<T: GLBaseSrcImpl>(ptr: *mut GstGLBaseSrc) {
109 let instance = &*(ptr as *mut T::Instance);
110 let imp = instance.imp();
111
112 gst::panic_to_error!(imp, (), { imp.gl_stop() })
113}
114
115unsafe extern "C" fn fill_gl_memory<T: GLBaseSrcImpl>(
116 ptr: *mut GstGLBaseSrc,
117 memory: *mut GstGLMemory,
118) -> glib::ffi::gboolean {
119 let instance = &*(ptr as *mut T::Instance);
120 let imp = instance.imp();
121
122 gst::panic_to_error!(imp, false, {
123 match imp.fill_gl_memory(&from_glib_borrow(memory)) {
124 Ok(()) => true,
125 Err(err) => {
126 err.log_with_imp(imp);
127 false
128 }
129 }
130 })
131 .into_glib()
132}