diff options
author | Narazaki Shuji | 2022-03-13 08:23:55 +0000 |
---|---|---|
committer | GitHub | 2022-03-13 08:23:55 +0000 |
commit | 05161aa85e14ec6cd84234d724639289027284fe (patch) | |
tree | 2c57b93fee4d33e10c02910fc08669a250b52256 /helix-term/src | |
parent | e8cc7ace759c2aaf3a14257a5c48e0f8a960d4cd (diff) |
Fix: insert_register (#1751)
- set register name correctly
- use autoinfo to display register contents
- call `paste` with `Paste::Cursor`
Diffstat (limited to 'helix-term/src')
-rw-r--r-- | helix-term/src/commands.rs | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/helix-term/src/commands.rs b/helix-term/src/commands.rs index b9401d40..844f6690 100644 --- a/helix-term/src/commands.rs +++ b/helix-term/src/commands.rs @@ -3038,6 +3038,7 @@ fn yank_main_selection_to_primary_clipboard(cx: &mut Context) { enum Paste { Before, After, + Cursor, } fn paste_impl( @@ -3084,6 +3085,8 @@ fn paste_impl( (Paste::Before, false) => range.from(), // paste append (Paste::After, false) => range.to(), + // paste at cursor + (Paste::Cursor, _) => range.cursor(text.slice(..)), }; (pos, pos, values.next()) }); @@ -3829,10 +3832,12 @@ fn select_register(cx: &mut Context) { } fn insert_register(cx: &mut Context) { + cx.editor.autoinfo = Some(Info::from_registers(&cx.editor.registers)); cx.on_next_key(move |cx, event| { if let Some(ch) = event.char() { - cx.editor.selected_register = Some(ch); - paste_before(cx); + cx.editor.autoinfo = None; + cx.register = Some(ch); + paste(cx, Paste::Cursor); } }) } |