From 6925daa823a86aa8d3fafe21591bb883cb053ef3 Mon Sep 17 00:00:00 2001 From: Joe Wilm Date: Fri, 11 Nov 2016 18:46:42 -0800 Subject: Fix/add some keybindings Adds support for pageup, pagedown, home, and end. Fixes delete inserting spaces. Resolves #15. --- src/event.rs | 8 ++++++++ src/input.rs | 27 +++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) (limited to 'src') diff --git a/src/event.rs b/src/event.rs index dcaedc97..6e28f289 100644 --- a/src/event.rs +++ b/src/event.rs @@ -41,11 +41,19 @@ impl Processor { match c { // Ignore BACKSPACE and DEL. These are handled specially. '\u{8}' | '\u{7f}' => (), + // Extra thing on macOS delete? + '\u{f728}' => (), // OSX arrow keys send invalid characters; ignore. '\u{f700}' | '\u{f701}' | '\u{f702}' | '\u{f703}' => (), + // Same with home/end. Am I missing something? Would be + // nice if glutin provided the received char in + // KeyboardInput event so a choice could be made there + // instead of having to special case everything. + '\u{f72b}' | '\u{f729}' | '\u{f72c}' | '\u{f72d}' => (), // These letters are handled in the bindings system 'v' => (), _ => { + println!("printing char {:?}", c); let buf = encode_char(c); self.notifier.notify(buf); } diff --git a/src/input.rs b/src/input.rs index da061449..1f9a82b2 100644 --- a/src/input.rs +++ b/src/input.rs @@ -187,6 +187,28 @@ static F12_BINDINGS: &'static [Binding] = &[ Binding { mods: mods::ANY, action: Action::Esc("\x1b[24~"), mode: mode::ANY, notmode: mode::NONE }, ]; +/// Bindings for PageUp +static PAGEUP_BINDINGS: &'static [Binding] = &[ + Binding { mods: mods::ANY, action: Action::Esc("\x1b[5~"), mode: mode::ANY, notmode: mode::NONE }, +]; + +/// Bindings for PageDown +static PAGEDOWN_BINDINGS: &'static [Binding] = &[ + Binding { mods: mods::ANY, action: Action::Esc("\x1b[6~"), mode: mode::ANY, notmode: mode::NONE }, +]; + +/// Bindings for Home +static HOME_BINDINGS: &'static [Binding] = &[ + Binding { mods: mods::ANY, action: Action::Esc("\x1b[H"), mode: mode::ANY, notmode: mode::APP_CURSOR }, + Binding { mods: mods::ANY, action: Action::Esc("\x1b[1~"), mode: mode::APP_CURSOR, notmode: mode::NONE }, +]; + +/// Bindings for End +static END_BINDINGS: &'static [Binding] = &[ + Binding { mods: mods::ANY, action: Action::Esc("\x1b[F"), mode: mode::ANY, notmode: mode::APP_CURSOR }, + Binding { mods: mods::ANY, action: Action::Esc("\x1b[4~"), mode: mode::APP_CURSOR, notmode: mode::NONE }, +]; + /// Bindings for the H key /// /// Control-H sends 0x08 normally, but we capture that in ReceivedCharacter @@ -297,6 +319,10 @@ impl Processor { VirtualKeyCode::F10 => F10_BINDINGS, VirtualKeyCode::F11 => F11_BINDINGS, VirtualKeyCode::F12 => F12_BINDINGS, + VirtualKeyCode::PageUp => PAGEUP_BINDINGS, + VirtualKeyCode::PageDown => PAGEDOWN_BINDINGS, + VirtualKeyCode::Home => HOME_BINDINGS, + VirtualKeyCode::End => END_BINDINGS, VirtualKeyCode::Back => BACKSPACE_BINDINGS, VirtualKeyCode::Delete => DELETE_BINDINGS, VirtualKeyCode::H => H_BINDINGS, @@ -346,6 +372,7 @@ impl Processor { // Modifier keys if binding.mods.is_all() || mods == binding.mods { // everything matches; run the binding action + println!("{:?}", binding); match binding.action { Action::Esc(s) => notifier.notify(s.as_bytes()), Action::Paste => { -- cgit v1.2.3-54-g00ecf