mirror of
https://github.com/rust-windowing/winit.git
synced 2026-06-27 07:03:15 -04:00
* Rename EventsLoop and associated types to EventLoop * Rename WindowEvent::Refresh to WindowEvent::Redraw * Remove second thread from win32 backend * Update run_forever to hijack thread * Replace windows Mutex with parking_lot Mutex * Implement new ControlFlow and associated events * Add StartCause::Init support, timer example * Add ability to send custom user events * Fully invert windows control flow so win32 calls into winit's callback * Add request_redraw * Rename platform to platform_impl * Rename os to platform, add Ext trait postfixes * Add platform::desktop module with EventLoopExt::run_return * Re-organize into module structure * Improve documentation * Small changes to examples * Improve docs for run and run_return * Change instances of "events_loop" to "event_loop" * Rename MonitorId to MonitorHandle * Add CHANGELOG entry * Improve WaitUntil timer precision * When SendEvent is called during event closure, buffer events * Fix resize lag when waiting in some situations * Update send test and errors that broke some examples/APIs * Improve clarity/fix typos in docs * Fix unreachable panic after setting ControlFlow to Poll during some RedrawRequested events. * Fix crash when running in release mode * Remove crossbeam dependency and make drop events work again * Remove serde implementations from ControlFlow * Fix 1.24.1 build * Fix freeze when setting decorations * Replace &EventLoop in callback with &EventLoopWindowTarget * Document and implement Debug for EventLoopWindowTarget * Fix some deadlocks that could occur when changing window state * Fix thread executor not executing closure when called from non-loop thread * Fix buffered events not getting dispatched * Fix crash with runner refcell not getting dropped * Address review feedback * Fix CHANGELOG typo * Catch panics in user callback
63 lines
1.6 KiB
Rust
63 lines
1.6 KiB
Rust
use std::ops::{Deref, DerefMut};
|
|
|
|
use super::*;
|
|
|
|
pub struct XSmartPointer<'a, T> {
|
|
xconn: &'a XConnection,
|
|
pub ptr: *mut T,
|
|
}
|
|
|
|
impl<'a, T> XSmartPointer<'a, T> {
|
|
// You're responsible for only passing things to this that should be XFree'd.
|
|
// Returns None if ptr is null.
|
|
pub fn new(xconn: &'a XConnection, ptr: *mut T) -> Option<Self> {
|
|
if !ptr.is_null() {
|
|
Some(XSmartPointer {
|
|
xconn,
|
|
ptr,
|
|
})
|
|
} else {
|
|
None
|
|
}
|
|
}
|
|
}
|
|
|
|
impl<'a, T> Deref for XSmartPointer<'a, T> {
|
|
type Target = T;
|
|
|
|
fn deref(&self) -> &T {
|
|
unsafe { &*self.ptr }
|
|
}
|
|
}
|
|
|
|
impl<'a, T> DerefMut for XSmartPointer<'a, T> {
|
|
fn deref_mut(&mut self) -> &mut T {
|
|
unsafe { &mut *self.ptr }
|
|
}
|
|
}
|
|
|
|
impl<'a, T> Drop for XSmartPointer<'a, T> {
|
|
fn drop(&mut self) {
|
|
unsafe {
|
|
(self.xconn.xlib.XFree)(self.ptr as *mut _);
|
|
}
|
|
}
|
|
}
|
|
|
|
impl XConnection {
|
|
pub fn alloc_class_hint(&self) -> XSmartPointer<ffi::XClassHint> {
|
|
XSmartPointer::new(self, unsafe { (self.xlib.XAllocClassHint)() })
|
|
.expect("`XAllocClassHint` returned null; out of memory")
|
|
}
|
|
|
|
pub fn alloc_size_hints(&self) -> XSmartPointer<ffi::XSizeHints> {
|
|
XSmartPointer::new(self, unsafe { (self.xlib.XAllocSizeHints)() })
|
|
.expect("`XAllocSizeHints` returned null; out of memory")
|
|
}
|
|
|
|
pub fn alloc_wm_hints(&self) -> XSmartPointer<ffi::XWMHints> {
|
|
XSmartPointer::new(self, unsafe { (self.xlib.XAllocWMHints)() })
|
|
.expect("`XAllocWMHints` returned null; out of memory")
|
|
}
|
|
}
|