From 8730388cdaaf2d42886593c310f1e65ed35b42a5 Mon Sep 17 00:00:00 2001 From: Ivan Tham Date: Sun, 13 Mar 2022 22:17:19 +0800 Subject: [PATCH] Perform extend line on every selection Currently `x` only affect the current selection, but this will make it affect every selection so `x` can be more useful with multi-cursors. --- helix-term/src/commands.rs | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/helix-term/src/commands.rs b/helix-term/src/commands.rs index 844f6690c546..17c28730e7e9 100644 --- a/helix-term/src/commands.rs +++ b/helix-term/src/commands.rs @@ -1841,17 +1841,20 @@ fn extend_line(cx: &mut Context) { let (view, doc) = current!(cx.editor); let text = doc.text(); - let range = doc.selection(view.id).primary(); + let selection = doc.selection(view.id).clone().transform(|range| { + let (start_line, end_line) = range.line_range(text.slice(..)); - let (start_line, end_line) = range.line_range(text.slice(..)); - let start = text.line_to_char(start_line); - let mut end = text.line_to_char((end_line + count).min(text.len_lines())); + let start = text.line_to_char(start_line); + let mut end = text.line_to_char((end_line + count).min(text.len_lines())); - if range.from() == start && range.to() == end { - end = text.line_to_char((end_line + count + 1).min(text.len_lines())); - } + // go to next line if current line is selected + if range.from() == start && range.to() == end { + end = text.line_to_char((end_line + count + 1).min(text.len_lines())); + } + Range::new(start, end) + }); - doc.set_selection(view.id, Selection::single(start, end)); + doc.set_selection(view.id, selection); } fn extend_to_line_bounds(cx: &mut Context) {