macOS: Fix doubled key repeats (#570)

This commit is contained in:
Francesca Frangipane 2018-06-17 15:08:26 -04:00 committed by GitHub
parent 38bc6babb7
commit 289fb47a34
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 10 additions and 6 deletions

View file

@ -14,6 +14,7 @@
- HiDPI support for Wayland. - HiDPI support for Wayland.
- `EventsLoop::get_available_monitors` and `EventsLoop::get_primary_monitor` now have identical counterparts on `Window`, so this information can be acquired without an `EventsLoop` borrow. - `EventsLoop::get_available_monitors` and `EventsLoop::get_primary_monitor` now have identical counterparts on `Window`, so this information can be acquired without an `EventsLoop` borrow.
- `AvailableMonitorsIter` now implements `Debug`. - `AvailableMonitorsIter` now implements `Debug`.
- Fixed quirk on macOS where certain keys would generate characters at twice the normal rate when held down.
# Version 0.15.1 (2018-06-13) # Version 0.15.1 (2018-06-13)

View file

@ -399,10 +399,10 @@ impl EventsLoop {
// If the mouse movement was on one of our windows, use it. // If the mouse movement was on one of our windows, use it.
// Otherwise, if one of our windows is the key window (receiving input), use it. // Otherwise, if one of our windows is the key window (receiving input), use it.
// Otherwise, return `None`. // Otherwise, return `None`.
let window = match maybe_window.or_else(maybe_key_window) { match maybe_window.or_else(maybe_key_window) {
Some(window) => window, Some(_window) => (),
None => return None, None => return None,
}; }
let mut events = std::collections::VecDeque::with_capacity(3); let mut events = std::collections::VecDeque::with_capacity(3);

View file

@ -396,11 +396,14 @@ extern fn key_down(this: &Object, _sel: Sel, event: id) {
.unwrap() .unwrap()
.push_back(window_event); .push_back(window_event);
} }
} else {
// Some keys (and only *some*, with no known reason) don't trigger `insertText`, while others do...
// So, we don't give repeats the opportunity to trigger that, since otherwise our hack will cause some
// keys to generate twice as many characters.
let array: id = msg_send![class("NSArray"), arrayWithObject:event];
let (): _ = msg_send![this, interpretKeyEvents:array];
} }
} }
let array: id = msg_send![class("NSArray"), arrayWithObject:event];
let (): _ = msg_send![this, interpretKeyEvents:array];
} }
} }