mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-12 05:31:31 +11:00
Add support for xcb
Due to XCB and Xlib compability, we can take a shortcut and use X11's underlying xcb_connection. This way, a complete XCB backend implementation can be avoided.
This commit is contained in:
parent
20afec5a14
commit
32d01b288e
|
@ -39,4 +39,4 @@ dwmapi-sys = "0.1"
|
||||||
wayland-client = { version = "0.5.4", features = ["dlopen"] }
|
wayland-client = { version = "0.5.4", features = ["dlopen"] }
|
||||||
wayland-kbd = "0.3.3"
|
wayland-kbd = "0.3.3"
|
||||||
wayland-window = "0.2.2"
|
wayland-window = "0.2.2"
|
||||||
x11-dl = "~2.4"
|
x11-dl = "2.8"
|
||||||
|
|
|
@ -4,4 +4,5 @@ pub use x11_dl::xf86vmode::*;
|
||||||
pub use x11_dl::xlib::*;
|
pub use x11_dl::xlib::*;
|
||||||
pub use x11_dl::xinput::*;
|
pub use x11_dl::xinput::*;
|
||||||
pub use x11_dl::xinput2::*;
|
pub use x11_dl::xinput2::*;
|
||||||
|
pub use x11_dl::xlib_xcb::*;
|
||||||
pub use x11_dl::error::OpenError;
|
pub use x11_dl::error::OpenError;
|
||||||
|
|
|
@ -694,6 +694,12 @@ impl Window {
|
||||||
self.x.window as *mut libc::c_void
|
self.x.window as *mut libc::c_void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_xcb_connection(&self) -> *mut libc::c_void {
|
||||||
|
unsafe {
|
||||||
|
(self.x.display.xlib_xcb.XGetXCBConnection)(self.get_xlib_display() as *mut _) as *mut _
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn set_window_resize_callback(&mut self, _: Option<fn(u32, u32)>) {
|
pub fn set_window_resize_callback(&mut self, _: Option<fn(u32, u32)>) {
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ pub struct XConnection {
|
||||||
pub xf86vmode: ffi::Xf86vmode,
|
pub xf86vmode: ffi::Xf86vmode,
|
||||||
pub xcursor: ffi::Xcursor,
|
pub xcursor: ffi::Xcursor,
|
||||||
pub xinput2: ffi::XInput2,
|
pub xinput2: ffi::XInput2,
|
||||||
|
pub xlib_xcb: ffi::Xlib_xcb,
|
||||||
pub display: *mut ffi::Display,
|
pub display: *mut ffi::Display,
|
||||||
pub latest_error: Mutex<Option<XError>>,
|
pub latest_error: Mutex<Option<XError>>,
|
||||||
}
|
}
|
||||||
|
@ -31,6 +32,7 @@ impl XConnection {
|
||||||
let xcursor = try!(ffi::Xcursor::open());
|
let xcursor = try!(ffi::Xcursor::open());
|
||||||
let xf86vmode = try!(ffi::Xf86vmode::open());
|
let xf86vmode = try!(ffi::Xf86vmode::open());
|
||||||
let xinput2 = try!(ffi::XInput2::open());
|
let xinput2 = try!(ffi::XInput2::open());
|
||||||
|
let xlib_xcb = try!(ffi::Xlib_xcb::open());
|
||||||
|
|
||||||
unsafe { (xlib.XInitThreads)() };
|
unsafe { (xlib.XInitThreads)() };
|
||||||
unsafe { (xlib.XSetErrorHandler)(error_handler) };
|
unsafe { (xlib.XSetErrorHandler)(error_handler) };
|
||||||
|
@ -49,6 +51,7 @@ impl XConnection {
|
||||||
xf86vmode: xf86vmode,
|
xf86vmode: xf86vmode,
|
||||||
xcursor: xcursor,
|
xcursor: xcursor,
|
||||||
xinput2: xinput2,
|
xinput2: xinput2,
|
||||||
|
xlib_xcb: xlib_xcb,
|
||||||
display: display,
|
display: display,
|
||||||
latest_error: Mutex::new(None),
|
latest_error: Mutex::new(None),
|
||||||
})
|
})
|
||||||
|
|
|
@ -21,6 +21,14 @@ pub trait WindowExt {
|
||||||
/// The pointer will become invalid when the glutin `Window` is destroyed.
|
/// The pointer will become invalid when the glutin `Window` is destroyed.
|
||||||
fn get_xlib_display(&self) -> Option<*mut libc::c_void>;
|
fn get_xlib_display(&self) -> Option<*mut libc::c_void>;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// This function returns the underlying `xcb_connection_t` of an xlib `Display`.
|
||||||
|
///
|
||||||
|
/// Returns `None` if the window doesn't use xlib (if it uses wayland for example).
|
||||||
|
///
|
||||||
|
/// The pointer will become invalid when the glutin `Window` is destroyed.
|
||||||
|
fn get_xcb_connection(&self) -> Option<*mut libc::c_void>;
|
||||||
|
|
||||||
/// Returns a pointer to the `wl_surface` object of wayland that is used by this window.
|
/// Returns a pointer to the `wl_surface` object of wayland that is used by this window.
|
||||||
///
|
///
|
||||||
/// Returns `None` if the window doesn't use wayland (if it uses xlib for example).
|
/// Returns `None` if the window doesn't use wayland (if it uses xlib for example).
|
||||||
|
@ -53,6 +61,13 @@ impl WindowExt for Window {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_xcb_connection(&self) -> Option<*mut libc::c_void> {
|
||||||
|
match self.window {
|
||||||
|
LinuxWindow::X(ref w) => Some(w.get_xcb_connection()),
|
||||||
|
_ => None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
fn get_wayland_surface(&self) -> Option<*mut libc::c_void> {
|
fn get_wayland_surface(&self) -> Option<*mut libc::c_void> {
|
||||||
match self.window {
|
match self.window {
|
||||||
|
|
Loading…
Reference in a new issue