mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 05:21:31 +11:00
parent
793c535b01
commit
5f7955cb2b
|
@ -8,6 +8,7 @@ And please only add new entries to the top of this list, right below the `# Unre
|
||||||
|
|
||||||
# Unreleased
|
# Unreleased
|
||||||
|
|
||||||
|
- On X11, set `visual_id` in returned `raw-window-handle`.
|
||||||
- **Breaking:** on Wayland, dispatching user created wayland queue won't wake up the loop unless winit has event to send back.
|
- **Breaking:** on Wayland, dispatching user created wayland queue won't wake up the loop unless winit has event to send back.
|
||||||
- Removed platform-specific extensions that should be retrieved through `raw-window-handle` trait implementations instead:
|
- Removed platform-specific extensions that should be retrieved through `raw-window-handle` trait implementations instead:
|
||||||
- `platform::windows::HINSTANCE`.
|
- `platform::windows::HINSTANCE`.
|
||||||
|
|
|
@ -113,6 +113,7 @@ unsafe impl Sync for UnownedWindow {}
|
||||||
pub(crate) struct UnownedWindow {
|
pub(crate) struct UnownedWindow {
|
||||||
pub(crate) xconn: Arc<XConnection>, // never changes
|
pub(crate) xconn: Arc<XConnection>, // never changes
|
||||||
xwindow: xproto::Window, // never changes
|
xwindow: xproto::Window, // never changes
|
||||||
|
visual: u32, // never changes
|
||||||
root: xproto::Window, // never changes
|
root: xproto::Window, // never changes
|
||||||
screen_id: i32, // never changes
|
screen_id: i32, // never changes
|
||||||
cursor: Mutex<CursorIcon>,
|
cursor: Mutex<CursorIcon>,
|
||||||
|
@ -252,7 +253,7 @@ impl UnownedWindow {
|
||||||
}
|
}
|
||||||
_ => (None, x11rb::COPY_FROM_PARENT as _, false),
|
_ => (None, x11rb::COPY_FROM_PARENT as _, false),
|
||||||
};
|
};
|
||||||
let visual = visualtype.map_or(x11rb::COPY_FROM_PARENT, |v| v.visual_id);
|
let mut visual = visualtype.map_or(x11rb::COPY_FROM_PARENT, |v| v.visual_id);
|
||||||
|
|
||||||
let window_attributes = {
|
let window_attributes = {
|
||||||
use xproto::EventMask;
|
use xproto::EventMask;
|
||||||
|
@ -319,10 +320,22 @@ impl UnownedWindow {
|
||||||
wid
|
wid
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// The COPY_FROM_PARENT is a special value for the visual used to copy
|
||||||
|
// the visual from the parent window, thus we have to query the visual
|
||||||
|
// we've got when we built the window above.
|
||||||
|
if visual == x11rb::COPY_FROM_PARENT {
|
||||||
|
visual = leap!(leap!(xconn
|
||||||
|
.xcb_connection()
|
||||||
|
.get_window_attributes(xwindow as xproto::Window))
|
||||||
|
.reply())
|
||||||
|
.visual;
|
||||||
|
}
|
||||||
|
|
||||||
#[allow(clippy::mutex_atomic)]
|
#[allow(clippy::mutex_atomic)]
|
||||||
let mut window = UnownedWindow {
|
let mut window = UnownedWindow {
|
||||||
xconn: Arc::clone(xconn),
|
xconn: Arc::clone(xconn),
|
||||||
xwindow: xwindow as xproto::Window,
|
xwindow: xwindow as xproto::Window,
|
||||||
|
visual,
|
||||||
root,
|
root,
|
||||||
screen_id,
|
screen_id,
|
||||||
cursor: Default::default(),
|
cursor: Default::default(),
|
||||||
|
@ -1745,6 +1758,7 @@ impl UnownedWindow {
|
||||||
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
pub fn raw_window_handle(&self) -> RawWindowHandle {
|
||||||
let mut window_handle = XlibWindowHandle::empty();
|
let mut window_handle = XlibWindowHandle::empty();
|
||||||
window_handle.window = self.xlib_window();
|
window_handle.window = self.xlib_window();
|
||||||
|
window_handle.visual_id = self.visual as c_ulong;
|
||||||
RawWindowHandle::Xlib(window_handle)
|
RawWindowHandle::Xlib(window_handle)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue