Fix extend line behavior.

This commit is contained in:
Nathan Vegdahl 2021-07-19 17:44:18 -07:00
parent e98d669c30
commit 13b0784009

View File

@ -1125,17 +1125,17 @@ fn extend_line(cx: &mut Context) {
let (view, doc) = current!(cx.editor); let (view, doc) = current!(cx.editor);
let text = doc.text(); let text = doc.text();
let pos = doc.selection(view.id).primary().min_width_1(text.slice(..)); let range = doc.selection(view.id).primary().min_width_1(text.slice(..));
let line_max = text.len_lines(); let start_line = text.char_to_line(range.from());
let start_line = text.char_to_line(pos.from()).min(line_max); let end_line = (text.char_to_line(range.to().saturating_sub(1).max(range.from())) + count)
let end_line = (text.char_to_line(pos.to()) + count).min(line_max); .min(text.len_lines());
let start = text.line_to_char(start_line); let start = text.line_to_char(start_line);
let mut end = text.line_to_char(end_line); let mut end = text.line_to_char(end_line);
if pos.from() == start && pos.to() == end { if range.from() == start && range.to() == end {
end = text.line_to_char((end_line + 1).min(line_max)); end = text.line_to_char((end_line + 1).min(text.len_lines()));
} }
doc.set_selection(view.id, Selection::single(start, end)); doc.set_selection(view.id, Selection::single(start, end));
@ -1148,12 +1148,15 @@ fn extend_to_line_bounds(cx: &mut Context) {
view.id, view.id,
doc.selection(view.id).clone().transform(|range| { doc.selection(view.id).clone().transform(|range| {
let text = doc.text(); let text = doc.text();
let start = text.line_to_char(text.char_to_line(range.from()));
let end = text
.line_to_char(text.char_to_line(range.to()) + 1)
.saturating_sub(1);
if range.anchor < range.head { let start_line = text.char_to_line(range.from());
let end_line = (text.char_to_line(range.to().saturating_sub(1).max(range.from())) + 1)
.min(text.len_lines());
let start = text.line_to_char(start_line);
let end = text.line_to_char(end_line);
if range.anchor <= range.head {
Range::new(start, end) Range::new(start, end)
} else { } else {
Range::new(end, start) Range::new(end, start)