mirror of
https://github.com/helix-editor/helix.git
synced 2024-11-23 01:46:18 +04:00
applied changes from pr review
This commit is contained in:
parent
9c3eadb2e4
commit
8bccd6df30
@ -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)
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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
|
||||||
),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user