Merge pull request #476 from aepsil0n/x11-cursor-grab-fix

Fix set_cursor_state on X11
This commit is contained in:
tomaka 2015-05-26 16:11:43 +02:00
commit a2507b6876

View file

@ -711,20 +711,22 @@ impl Window {
}
pub fn set_cursor_state(&self, state: CursorState) -> Result<(), String> {
use CursorState::{ Grab, Normal };
let mut cursor_state = self.cursor_state.lock().unwrap();
match (state, *cursor_state) {
(CursorState::Normal, CursorState::Grab) => {
(Normal, Grab) => {
unsafe {
(self.x.display.xlib.XUngrabPointer)(self.x.display.display, ffi::CurrentTime);
*cursor_state = CursorState::Normal;
*cursor_state = Normal;
Ok(())
}
},
(CursorState::Grab, CursorState::Normal) => {
(Grab, Normal) => {
unsafe {
*cursor_state = CursorState::Grab;
*cursor_state = Grab;
match (self.x.display.xlib.XGrabPointer)(
self.x.display.display, self.x.window, ffi::False,
@ -745,6 +747,9 @@ impl Window {
}
},
// Nothing needs to change
(Grab, Grab) | (Normal, Normal) => Ok(()),
_ => unimplemented!(),
}
}