smithay/src/backend/graphics/glium.rs

108 lines
3.3 KiB
Rust
Raw Normal View History

2017-06-02 11:16:12 +00:00
//! Glium compatibility module
use backend::graphics::egl::{EGLGraphicsBackend, SwapBuffersError, EglExtensionNotSupportedError};
use backend::graphics::egl::wayland::{BufferAccessError, EGLImages, EGLWaylandExtensions, EGLDisplay};
use backend::graphics::egl::error::Result as EGLResult;
2017-06-02 11:16:12 +00:00
use glium::Frame;
2017-03-07 10:53:57 +00:00
use glium::SwapBuffersError as GliumSwapBuffersError;
2017-06-13 14:52:17 +00:00
use glium::backend::{Backend, Context, Facade};
2017-06-02 11:16:12 +00:00
use glium::debug::DebugCallbackBehavior;
2017-09-21 17:05:59 +00:00
use std::borrow::Borrow;
2017-03-18 16:27:49 +00:00
use std::os::raw::c_void;
2017-06-02 11:16:12 +00:00
use std::rc::Rc;
use wayland_server::Display;
use wayland_server::protocol::wl_buffer::WlBuffer;
2017-06-02 11:16:12 +00:00
2017-03-20 13:33:27 +00:00
impl From<SwapBuffersError> for GliumSwapBuffersError {
2017-03-07 10:53:57 +00:00
fn from(error: SwapBuffersError) -> Self {
match error {
SwapBuffersError::ContextLost => GliumSwapBuffersError::ContextLost,
SwapBuffersError::AlreadySwapped => GliumSwapBuffersError::AlreadySwapped,
2017-10-01 17:21:12 +00:00
SwapBuffersError::Unknown(_) => GliumSwapBuffersError::ContextLost, // TODO
2017-03-07 10:53:57 +00:00
}
}
}
2017-06-02 11:16:12 +00:00
/// Wrapper to expose `glium` compatibility
pub struct GliumGraphicsBackend<T: EGLGraphicsBackend> {
context: Rc<Context>,
backend: Rc<InternalBackend<T>>,
}
struct InternalBackend<T: EGLGraphicsBackend>(T);
impl<T: EGLGraphicsBackend + 'static> GliumGraphicsBackend<T> {
fn new(backend: T) -> GliumGraphicsBackend<T> {
let internal = Rc::new(InternalBackend(backend));
GliumGraphicsBackend {
// cannot fail
context: unsafe {
Context::new(internal.clone(), true, DebugCallbackBehavior::default()).unwrap()
2017-06-02 11:16:12 +00:00
},
backend: internal,
}
}
/// Start drawing on the backbuffer.
///
/// This function returns a `Frame`, which can be used to draw on it. When the `Frame` is
/// destroyed, the buffers are swapped.
///
/// Note that destroying a `Frame` is immediate, even if vsync is enabled.
#[inline]
pub fn draw(&self) -> Frame {
2017-06-20 09:31:18 +00:00
Frame::new(
self.context.clone(),
self.backend.get_framebuffer_dimensions(),
)
2017-06-02 11:16:12 +00:00
}
}
2017-09-21 17:05:59 +00:00
impl<T: EGLGraphicsBackend> Borrow<T> for GliumGraphicsBackend<T> {
fn borrow(&self) -> &T {
&self.backend.0
2017-06-02 11:16:12 +00:00
}
}
2017-03-18 16:27:49 +00:00
2017-06-13 14:52:17 +00:00
impl<T: EGLGraphicsBackend> Facade for GliumGraphicsBackend<T> {
fn get_context(&self) -> &Rc<Context> {
&self.context
}
}
2017-09-20 17:48:58 +00:00
impl<T: EGLGraphicsBackend + 'static> From<T> for GliumGraphicsBackend<T> {
fn from(backend: T) -> Self {
GliumGraphicsBackend::new(backend)
2017-03-18 16:27:49 +00:00
}
}
impl<T: EGLGraphicsBackend + EGLWaylandExtensions + 'static> EGLWaylandExtensions for GliumGraphicsBackend<T> {
fn bind_wl_display(&self, display: &Display) -> EGLResult<EGLDisplay> {
(*self.backend).0.bind_wl_display(display)
}
}
2017-06-02 11:16:12 +00:00
unsafe impl<T: EGLGraphicsBackend> Backend for InternalBackend<T> {
2017-03-18 16:27:49 +00:00
fn swap_buffers(&self) -> Result<(), GliumSwapBuffersError> {
self.0.swap_buffers().map_err(Into::into)
2017-03-07 10:53:57 +00:00
}
2017-03-20 13:33:27 +00:00
unsafe fn get_proc_address(&self, symbol: &str) -> *const c_void {
2017-03-18 16:27:49 +00:00
self.0.get_proc_address(symbol) as *const c_void
2017-03-07 10:53:57 +00:00
}
fn get_framebuffer_dimensions(&self) -> (u32, u32) {
2017-03-18 16:27:49 +00:00
self.0.get_framebuffer_dimensions()
2017-03-07 10:53:57 +00:00
}
fn is_current(&self) -> bool {
2017-03-18 16:27:49 +00:00
self.0.is_current()
2017-03-07 10:53:57 +00:00
}
unsafe fn make_current(&self) {
2017-05-18 20:28:02 +00:00
self.0.make_current().expect("Context was lost")
2017-03-07 10:53:57 +00:00
}
}