Simplify line ending calculation.

pull/1/head
Blaž Hrastnik 4 years ago
parent 13d1ea542e
commit 1bb01d27ae

@ -159,10 +159,9 @@ impl State {
(Direction::Forward, Granularity::Character) => { (Direction::Forward, Granularity::Character) => {
// Clamp to line // Clamp to line
let line = text.char_to_line(pos); let line = text.char_to_line(pos);
let start = text.line_to_char(line); // Line end is pos at the start of next line - 1
let len = text.line(line).len_chars(); // subtract another 1 because the line ends with \n
// convert to 0-indexed, subtract another 1 because len_chars() counts \n let end = text.line_to_char(line + 1).saturating_sub(2);
let end = start + len.saturating_sub(2);
std::cmp::min(nth_next_grapheme_boundary(&text.slice(..), pos, count), end) std::cmp::min(nth_next_grapheme_boundary(&text.slice(..), pos, count), end)
} }
(Direction::Forward, Granularity::Word) => { (Direction::Forward, Granularity::Word) => {

@ -50,9 +50,10 @@ pub fn move_line_end(view: &mut View, count: usize) {
.into_iter() .into_iter()
.map(|index| { .map(|index| {
// adjust all positions to the end of the line. // adjust all positions to the end of the line.
let line = view.state.doc.line(index);
let line_start = view.state.doc.line_to_char(index); // Line end is pos at the start of next line - 1
line_start + line.len_chars() - 1 // subtract another 1 because the line ends with \n
view.state.doc.line_to_char(index + 1).saturating_sub(2)
}) })
.map(|pos| Range::new(pos, pos)); .map(|pos| Range::new(pos, pos));
@ -236,10 +237,8 @@ pub fn open_below(view: &mut View, _count: usize) {
let positions: Vec<_> = lines let positions: Vec<_> = lines
.into_iter() .into_iter()
.map(|index| { .map(|index| {
// adjust all positions to the end of the line. // adjust all positions to the end of the line/start of the next one.
let line = view.state.doc.line(index); view.state.doc.line_to_char(index + 1)
let line_start = view.state.doc.line_to_char(index);
line_start + line.len_chars()
}) })
.collect(); .collect();

Loading…
Cancel
Save