mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-24 18:08:15 +00:00
gtk4: Handle more GL context creation failures gracefully
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/1038>
This commit is contained in:
parent
37dedfd4d0
commit
696944c08e
1 changed files with 56 additions and 24 deletions
|
@ -26,8 +26,6 @@ use std::sync::{Mutex, MutexGuard};
|
||||||
|
|
||||||
use crate::utils;
|
use crate::utils;
|
||||||
|
|
||||||
#[cfg(any(target_os = "macos", feature = "gst_gl"))]
|
|
||||||
use glib::translate::*;
|
|
||||||
#[cfg(any(target_os = "macos", feature = "gst_gl"))]
|
#[cfg(any(target_os = "macos", feature = "gst_gl"))]
|
||||||
use gst_gl::prelude::GLContextExt as GstGLContextExt;
|
use gst_gl::prelude::GLContextExt as GstGLContextExt;
|
||||||
#[cfg(any(target_os = "macos", feature = "gst_gl"))]
|
#[cfg(any(target_os = "macos", feature = "gst_gl"))]
|
||||||
|
@ -757,22 +755,31 @@ impl PaintableSink {
|
||||||
|
|
||||||
// FIXME: bindings
|
// FIXME: bindings
|
||||||
unsafe {
|
unsafe {
|
||||||
|
use glib::translate::*;
|
||||||
|
|
||||||
let d = display.downcast::<gdk_x11::X11Display>().unwrap();
|
let d = display.downcast::<gdk_x11::X11Display>().unwrap();
|
||||||
let x11_display = gdk_x11::ffi::gdk_x11_display_get_egl_display(d.to_glib_none().0);
|
let x11_display = gdk_x11::ffi::gdk_x11_display_get_egl_display(d.to_glib_none().0);
|
||||||
assert!(!x11_display.is_null());
|
if x11_display.is_null() {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to get EGL display");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
let gst_display = gst_gl_egl::ffi::gst_gl_display_egl_new_with_egl_display(x11_display);
|
let gst_display = gst_gl_egl::ffi::gst_gl_display_egl_new_with_egl_display(x11_display);
|
||||||
assert!(!gst_display.is_null());
|
let gst_display =
|
||||||
let gst_display: gst_gl::GLDisplay =
|
gst_gl::GLDisplay::from_glib_full(gst_display as *mut gst_gl::ffi::GstGLDisplay);
|
||||||
from_glib_full(gst_display as *mut gst_gl::ffi::GstGLDisplay);
|
|
||||||
|
|
||||||
let gst_app_context =
|
let gst_app_context =
|
||||||
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
||||||
|
let gst_app_context = match gst_app_context {
|
||||||
assert!(gst_app_context.is_some());
|
None => {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to create wrapped GL context");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Some(gst_app_context) => gst_app_context,
|
||||||
|
};
|
||||||
|
|
||||||
display_ctx_guard.replace(gst_display);
|
display_ctx_guard.replace(gst_display);
|
||||||
app_ctx_guard.replace(gst_app_context.unwrap());
|
app_ctx_guard.replace(gst_app_context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -800,22 +807,31 @@ impl PaintableSink {
|
||||||
|
|
||||||
// FIXME: bindings
|
// FIXME: bindings
|
||||||
unsafe {
|
unsafe {
|
||||||
|
use glib::translate::*;
|
||||||
|
|
||||||
let d = display.downcast::<gdk_x11::X11Display>().unwrap();
|
let d = display.downcast::<gdk_x11::X11Display>().unwrap();
|
||||||
let x11_display = gdk_x11::ffi::gdk_x11_display_get_xdisplay(d.to_glib_none().0);
|
let x11_display = gdk_x11::ffi::gdk_x11_display_get_xdisplay(d.to_glib_none().0);
|
||||||
assert!(!x11_display.is_null());
|
if x11_display.is_null() {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to get X11 display");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
let gst_display = gst_gl_x11::ffi::gst_gl_display_x11_new_with_display(x11_display);
|
let gst_display = gst_gl_x11::ffi::gst_gl_display_x11_new_with_display(x11_display);
|
||||||
assert!(!gst_display.is_null());
|
let gst_display =
|
||||||
let gst_display: gst_gl::GLDisplay =
|
gst_gl::GLDisplay::from_glib_full(gst_display as *mut gst_gl::ffi::GstGLDisplay);
|
||||||
from_glib_full(gst_display as *mut gst_gl::ffi::GstGLDisplay);
|
|
||||||
|
|
||||||
let gst_app_context =
|
let gst_app_context =
|
||||||
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
||||||
|
let gst_app_context = match gst_app_context {
|
||||||
assert!(gst_app_context.is_some());
|
None => {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to create wrapped GL context");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Some(gst_app_context) => gst_app_context,
|
||||||
|
};
|
||||||
|
|
||||||
display_ctx_guard.replace(gst_display);
|
display_ctx_guard.replace(gst_display);
|
||||||
app_ctx_guard.replace(gst_app_context.unwrap());
|
app_ctx_guard.replace(gst_app_context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -843,26 +859,36 @@ impl PaintableSink {
|
||||||
|
|
||||||
// FIXME: bindings
|
// FIXME: bindings
|
||||||
unsafe {
|
unsafe {
|
||||||
|
use glib::translate::*;
|
||||||
|
|
||||||
// let wayland_display = gdk_wayland::WaylandDisplay::wl_display(display.downcast());
|
// let wayland_display = gdk_wayland::WaylandDisplay::wl_display(display.downcast());
|
||||||
// get the ptr directly since we are going to use it raw
|
// get the ptr directly since we are going to use it raw
|
||||||
let d = display.downcast::<gdk_wayland::WaylandDisplay>().unwrap();
|
let d = display.downcast::<gdk_wayland::WaylandDisplay>().unwrap();
|
||||||
let wayland_display =
|
let wayland_display =
|
||||||
gdk_wayland::ffi::gdk_wayland_display_get_wl_display(d.to_glib_none().0);
|
gdk_wayland::ffi::gdk_wayland_display_get_wl_display(d.to_glib_none().0);
|
||||||
assert!(!wayland_display.is_null());
|
if wayland_display.is_null() {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to get Wayland display");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
let gst_display =
|
let gst_display =
|
||||||
gst_gl_wayland::ffi::gst_gl_display_wayland_new_with_display(wayland_display);
|
gst_gl_wayland::ffi::gst_gl_display_wayland_new_with_display(wayland_display);
|
||||||
assert!(!gst_display.is_null());
|
let gst_display =
|
||||||
let gst_display: gst_gl::GLDisplay =
|
gst_gl::GLDisplay::from_glib_full(gst_display as *mut gst_gl::ffi::GstGLDisplay);
|
||||||
from_glib_full(gst_display as *mut gst_gl::ffi::GstGLDisplay);
|
|
||||||
|
|
||||||
let gst_app_context =
|
let gst_app_context =
|
||||||
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
||||||
|
|
||||||
assert!(gst_app_context.is_some());
|
let gst_app_context = match gst_app_context {
|
||||||
|
None => {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to create wrapped GL context");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Some(gst_app_context) => gst_app_context,
|
||||||
|
};
|
||||||
|
|
||||||
display_ctx_guard.replace(gst_display);
|
display_ctx_guard.replace(gst_display);
|
||||||
app_ctx_guard.replace(gst_app_context.unwrap());
|
app_ctx_guard.replace(gst_app_context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -893,10 +919,16 @@ impl PaintableSink {
|
||||||
let gst_app_context =
|
let gst_app_context =
|
||||||
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
gst_gl::GLContext::new_wrapped(&gst_display, gl_ctx, platform, gl_api);
|
||||||
|
|
||||||
assert!(gst_app_context.is_some());
|
let gst_app_context = match gst_app_context {
|
||||||
|
None => {
|
||||||
|
gst::error!(CAT, imp: self, "Failed to create wrapped GL context");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Some(gst_app_context) => gst_app_context,
|
||||||
|
};
|
||||||
|
|
||||||
display_ctx_guard.replace(gst_display);
|
display_ctx_guard.replace(gst_display);
|
||||||
app_ctx_guard.replace(gst_app_context.unwrap());
|
app_ctx_guard.replace(gst_app_context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue