applied changes from pr review

This commit is contained in:
Jan Hrastnik 2021-06-17 13:49:50 +02:00
parent 9c3eadb2e4
commit 8bccd6df30
3 changed files with 39 additions and 34 deletions

View File

@ -13,6 +13,29 @@ pub enum LineEnding {
PS, // U+2029 -- ParagraphSeparator PS, // U+2029 -- ParagraphSeparator
} }
impl LineEnding {
pub fn len(&self) -> usize {
match self {
Self::Crlf => 2,
_ => 1,
}
}
pub fn as_str(&self) -> &str {
match self {
Self::Crlf => "\u{000D}\u{000A}",
Self::LF => "\u{000A}",
Self::Nel => "\u{0085}",
Self::LS => "\u{2028}",
Self::CR => "\u{000D}",
_ => panic!(
"Unexpected line ending: {:?}, expected Crlf, LF, CR, Nel, or LS.",
self
),
}
}
}
pub fn rope_slice_to_line_ending(g: &RopeSlice) -> Option<LineEnding> { pub fn rope_slice_to_line_ending(g: &RopeSlice) -> Option<LineEnding> {
if let Some(text) = g.as_str() { if let Some(text) = g.as_str() {
str_to_line_ending(text) str_to_line_ending(text)

View File

@ -184,14 +184,10 @@ pub fn move_line_end(cx: &mut Context) {
let line = text.char_to_line(range.head); let line = text.char_to_line(range.head);
// Line end is pos at the start of next line - 1 // Line end is pos at the start of next line - 1
// subtract 3 if the line ending is \r\n, otherwise subtract 2 as I assume all others are just 1 char length // subtract another 1 because the line ends with \n
let pos = let pos = text
text.line_to_char(line + 1) .line_to_char(line + 1)
.saturating_sub(if doc.line_ending == LineEnding::Crlf { .saturating_sub(doc.line_ending().len() + 1);
3
} else {
2
});
Range::new(pos, pos) Range::new(pos, pos)
}); });
@ -612,14 +608,10 @@ pub fn extend_line_end(cx: &mut Context) {
let line = text.char_to_line(range.head); let line = text.char_to_line(range.head);
// Line end is pos at the start of next line - 1 // Line end is pos at the start of next line - 1
// subtract 3 if the line ending is \r\n, otherwise subtract 2 as I assume all others are just 1 char length // subtract another 1 because the line ends with \n
let pos = let pos = text
text.line_to_char(line + 1) .line_to_char(line + 1)
.saturating_sub(if doc.line_ending == LineEnding::Crlf { .saturating_sub(doc.line_ending().len() + 1);
3
} else {
2
});
Range::new(range.anchor, pos) Range::new(range.anchor, pos)
}); });
@ -908,7 +900,7 @@ pub fn append_mode(cx: &mut Context) {
if selection.iter().any(|range| range.head == end) { if selection.iter().any(|range| range.head == end) {
let transaction = Transaction::change( let transaction = Transaction::change(
doc.text(), doc.text(),
std::array::IntoIter::new([(end, end, Some(Tendril::from_char('\n')))]), // TODO: change \n to doc.line_ending() std::array::IntoIter::new([(end, end, Some(doc.line_ending().as_str().into()))]),
); );
doc.apply(&transaction, view.id); doc.apply(&transaction, view.id);
} }
@ -1535,7 +1527,7 @@ fn open(cx: &mut Context, open: Open) {
); );
let indent = doc.indent_unit().repeat(indent_level); let indent = doc.indent_unit().repeat(indent_level);
let mut text = String::with_capacity(1 + indent.len()); let mut text = String::with_capacity(1 + indent.len());
text.push_str(doc.line_ending()); text.push_str(doc.line_ending().as_str());
text.push_str(&indent); text.push_str(&indent);
let text = text.repeat(count); let text = text.repeat(count);
@ -2143,7 +2135,7 @@ pub fn insert_newline(cx: &mut Context) {
); );
let indent = doc.indent_unit().repeat(indent_level); let indent = doc.indent_unit().repeat(indent_level);
let mut text = String::with_capacity(1 + indent.len()); let mut text = String::with_capacity(1 + indent.len());
text.push_str(doc.line_ending()); text.push_str(doc.line_ending().as_str());
text.push_str(&indent); text.push_str(&indent);
let head = pos + offs + text.chars().count(); let head = pos + offs + text.chars().count();
@ -2164,7 +2156,7 @@ pub fn insert_newline(cx: &mut Context) {
if helix_core::auto_pairs::PAIRS.contains(&(prev, curr)) { if helix_core::auto_pairs::PAIRS.contains(&(prev, curr)) {
// another newline, indent the end bracket one level less // another newline, indent the end bracket one level less
let indent = doc.indent_unit().repeat(indent_level.saturating_sub(1)); let indent = doc.indent_unit().repeat(indent_level.saturating_sub(1));
text.push_str(doc.line_ending()); text.push_str(doc.line_ending().as_str());
text.push_str(&indent); text.push_str(&indent);
} }
@ -2283,7 +2275,7 @@ fn paste_impl(
// if any of values ends \n it's linewise paste // if any of values ends \n it's linewise paste
let linewise = values let linewise = values
.iter() .iter()
.any(|value| value.ends_with(doc.line_ending())); .any(|value| value.ends_with(doc.line_ending().as_str()));
let mut values = values.iter().cloned().map(Tendril::from).chain(repeat); let mut values = values.iter().cloned().map(Tendril::from).chain(repeat);

View File

@ -63,7 +63,7 @@ pub struct Document {
diagnostics: Vec<Diagnostic>, diagnostics: Vec<Diagnostic>,
language_server: Option<Arc<helix_lsp::Client>>, language_server: Option<Arc<helix_lsp::Client>>,
pub line_ending: LineEnding, line_ending: LineEnding,
} }
use std::fmt; use std::fmt;
@ -728,18 +728,8 @@ pub fn set_diagnostics(&mut self, diagnostics: Vec<Diagnostic>) {
self.diagnostics = diagnostics; self.diagnostics = diagnostics;
} }
pub fn line_ending(&self) -> &'static str { pub fn line_ending(&self) -> LineEnding {
match self.line_ending {
LineEnding::Crlf => "\u{000D}\u{000A}",
LineEnding::LF => "\u{000A}",
LineEnding::Nel => "\u{0085}",
LineEnding::LS => "\u{2028}",
LineEnding::CR => "\u{000D}",
_ => panic!(
"Unexpected line ending: {:?}, expected Crlf, LF, CR, Nel, or LS.",
self.line_ending self.line_ending
),
}
} }
} }