// Welcome to the util module, where we try to keep you from shooting yourself in the foot. // *results may vary use std::mem::{self, MaybeUninit}; use std::ops::BitAnd; use std::os::raw::*; mod client_msg; pub mod cookie; mod cursor; mod geometry; mod hint; mod icon; mod input; pub mod keys; pub(crate) mod memory; mod mouse; mod randr; mod window_property; mod wm; mod xmodmap; use x11rb::protocol::xproto::{self, ConnectionExt as _}; pub use self::cursor::*; pub use self::geometry::*; pub use self::hint::*; pub(crate) use self::icon::rgba_to_cardinals; pub use self::input::*; pub use self::mouse::*; pub use self::window_property::*; pub use self::wm::*; pub use self::xmodmap::ModifierKeymap; use super::atoms::*; use super::{ffi, VoidCookie, X11Error, XConnection, XError}; pub fn maybe_change(field: &mut Option, value: T) -> bool { let wrapped = Some(value); if *field != wrapped { *field = wrapped; true } else { false } } pub fn has_flag(bitset: T, flag: T) -> bool where T: Copy + PartialEq + BitAnd, { bitset & flag == flag } impl XConnection { // This is important, so pay attention! // Xlib has an output buffer, and tries to hide the async nature of X from you. // This buffer contains the requests you make, and is flushed under various circumstances: // 1. `XPending`, `XNextEvent`, and `XWindowEvent` flush "as needed" // 2. `XFlush` explicitly flushes // 3. `XSync` flushes and blocks until all requests are responded to // 4. Calls that have a return dependent on a response (i.e. `XGetWindowProperty`) sync // internally. When in doubt, check the X11 source; if a function calls `_XReply`, it flushes // and waits. // All util functions that abstract an async function will return a `Flusher`. pub fn flush_requests(&self) -> Result<(), XError> { unsafe { (self.xlib.XFlush)(self.display) }; // println!("XFlush"); // This isn't necessarily a useful time to check for errors (since our request hasn't // necessarily been processed yet) self.check_errors() } pub fn sync_with_server(&self) -> Result<(), XError> { unsafe { (self.xlib.XSync)(self.display, ffi::False) }; // println!("XSync"); self.check_errors() } }