From 0c2b99327a60d478ff6a4e4a2a15f69e61857569 Mon Sep 17 00:00:00 2001 From: Wojciech Kępka Date: Fri, 11 Jun 2021 09:30:27 +0200 Subject: commands: Handle `t` as till newline --- helix-term/src/commands.rs | 46 ++++++++++++++++++++++++++-------------------- 1 file changed, 26 insertions(+), 20 deletions(-) (limited to 'helix-term') diff --git a/helix-term/src/commands.rs b/helix-term/src/commands.rs index d8c56f4e..e5a30687 100644 --- a/helix-term/src/commands.rs +++ b/helix-term/src/commands.rs @@ -348,28 +348,34 @@ where // need to wait for next key cx.on_next_key(move |cx, event| { - if let KeyEvent { - code: KeyCode::Char(ch), - .. - } = event - { - let (view, doc) = cx.current(); - let text = doc.text().slice(..); + let ch = match event { + KeyEvent { + code: KeyCode::Enter, + .. + } => '\n', + KeyEvent { + code: KeyCode::Char(ch), + .. + } => ch, + _ => return, + }; - let selection = doc.selection(view.id).transform(|mut range| { - search_fn(text, ch, range.head, count, inclusive).map_or(range, |pos| { - if extend { - Range::new(range.anchor, pos) - } else { - // select - Range::new(range.head, pos) - } - // or (pos, pos) to move to found val - }) - }); + let (view, doc) = cx.current(); + let text = doc.text().slice(..); - doc.set_selection(view.id, selection); - } + let selection = doc.selection(view.id).transform(|mut range| { + search_fn(text, ch, range.head, count, inclusive).map_or(range, |pos| { + if extend { + Range::new(range.anchor, pos) + } else { + // select + Range::new(range.head, pos) + } + // or (pos, pos) to move to found val + }) + }); + + doc.set_selection(view.id, selection); }) } -- cgit v1.2.3-70-g09d2