Rename NewlineStyle -> LineEnding

This commit is contained in:
Max Brunsfeld 2022-07-04 12:47:40 -07:00
parent 0ba12eab22
commit 9804c683c0
7 changed files with 58 additions and 58 deletions

View File

@ -22,7 +22,7 @@ use gpui::{
};
use language::{
range_to_lsp, tree_sitter_rust, Diagnostic, DiagnosticEntry, FakeLspAdapter, Language,
LanguageConfig, LanguageRegistry, NewlineStyle, OffsetRangeExt, Point, Rope,
LanguageConfig, LanguageRegistry, LineEnding, OffsetRangeExt, Point, Rope,
};
use lsp::{self, FakeLanguageServer};
use parking_lot::Mutex;
@ -1266,7 +1266,7 @@ async fn test_buffer_reloading(cx_a: &mut TestAppContext, cx_b: &mut TestAppCont
.save(
"/dir/a.txt".as_ref(),
&"new contents".into(),
NewlineStyle::Unix,
LineEnding::Unix,
)
.await
.unwrap();
@ -1864,7 +1864,7 @@ async fn test_reloading_buffer_manually(cx_a: &mut TestAppContext, cx_b: &mut Te
.save(
"/a/a.rs".as_ref(),
&Rope::from("let seven = 7;"),
NewlineStyle::Unix,
LineEnding::Unix,
)
.await
.unwrap();

View File

@ -53,7 +53,7 @@ pub struct Buffer {
saved_version: clock::Global,
saved_version_fingerprint: String,
saved_mtime: SystemTime,
newline_style: NewlineStyle,
line_ending: LineEnding,
transaction_depth: usize,
was_dirty_before_starting_transaction: Option<bool>,
language: Option<Arc<Language>>,
@ -99,7 +99,7 @@ pub enum IndentKind {
}
#[derive(Copy, Debug, Clone, PartialEq, Eq)]
pub enum NewlineStyle {
pub enum LineEnding {
Unix,
Windows,
}
@ -201,7 +201,7 @@ pub trait File: Send + Sync {
buffer_id: u64,
text: Rope,
version: clock::Global,
newline_style: NewlineStyle,
line_ending: LineEnding,
cx: &mut MutableAppContext,
) -> Task<Result<(clock::Global, String, SystemTime)>>;
@ -283,7 +283,7 @@ pub(crate) struct Diff {
base_version: clock::Global,
new_text: Arc<str>,
changes: Vec<(ChangeTag, usize)>,
newline_style: NewlineStyle,
line_ending: LineEnding,
start_offset: usize,
}
@ -319,11 +319,11 @@ impl Buffer {
cx: &mut ModelContext<Self>,
) -> Self {
let history = History::new(base_text.into());
let newline_style = NewlineStyle::detect(&history.base_text);
let line_ending = LineEnding::detect(&history.base_text);
Self::build(
TextBuffer::new(replica_id, cx.model_id() as u64, history),
None,
newline_style,
line_ending,
)
}
@ -334,11 +334,11 @@ impl Buffer {
cx: &mut ModelContext<Self>,
) -> Self {
let history = History::new(base_text.into());
let newline_style = NewlineStyle::detect(&history.base_text);
let line_ending = LineEnding::detect(&history.base_text);
Self::build(
TextBuffer::new(replica_id, cx.model_id() as u64, history),
Some(file),
newline_style,
line_ending,
)
}
@ -353,9 +353,9 @@ impl Buffer {
message.id,
History::new(Arc::from(message.base_text)),
);
let newline_style = proto::NewlineStyle::from_i32(message.newline_style)
.ok_or_else(|| anyhow!("missing newline_style"))?;
let mut this = Self::build(buffer, file, NewlineStyle::from_proto(newline_style));
let line_ending = proto::LineEnding::from_i32(message.line_ending)
.ok_or_else(|| anyhow!("missing line_ending"))?;
let mut this = Self::build(buffer, file, LineEnding::from_proto(line_ending));
let ops = message
.operations
.into_iter()
@ -420,7 +420,7 @@ impl Buffer {
diagnostics: proto::serialize_diagnostics(self.diagnostics.iter()),
diagnostics_timestamp: self.diagnostics_timestamp.value,
completion_triggers: self.completion_triggers.clone(),
newline_style: self.newline_style.to_proto() as i32,
line_ending: self.line_ending.to_proto() as i32,
}
}
@ -429,7 +429,7 @@ impl Buffer {
self
}
fn build(buffer: TextBuffer, file: Option<Arc<dyn File>>, newline_style: NewlineStyle) -> Self {
fn build(buffer: TextBuffer, file: Option<Arc<dyn File>>, line_ending: LineEnding) -> Self {
let saved_mtime;
if let Some(file) = file.as_ref() {
saved_mtime = file.mtime();
@ -445,7 +445,7 @@ impl Buffer {
was_dirty_before_starting_transaction: None,
text: buffer,
file,
newline_style,
line_ending,
syntax_tree: Mutex::new(None),
parsing_in_background: false,
parse_count: 0,
@ -506,7 +506,7 @@ impl Buffer {
self.remote_id(),
text,
version,
self.newline_style,
self.line_ending,
cx.as_mut(),
);
cx.spawn(|this, mut cx| async move {
@ -974,7 +974,7 @@ impl Buffer {
let base_version = self.version();
cx.background().spawn(async move {
let old_text = old_text.to_string();
let newline_style = NewlineStyle::detect(&new_text);
let line_ending = LineEnding::detect(&new_text);
let new_text = new_text.replace("\r\n", "\n").replace('\r', "\n");
let changes = TextDiff::from_lines(old_text.as_str(), new_text.as_str())
.iter_all_changes()
@ -984,7 +984,7 @@ impl Buffer {
base_version,
new_text: new_text.into(),
changes,
newline_style,
line_ending,
start_offset: 0,
}
})
@ -998,7 +998,7 @@ impl Buffer {
if self.version == diff.base_version {
self.finalize_last_transaction();
self.start_transaction();
self.newline_style = diff.newline_style;
self.line_ending = diff.line_ending;
let mut offset = diff.start_offset;
for (tag, len) in diff.changes {
let range = offset..(offset + len);
@ -1514,8 +1514,8 @@ impl Buffer {
&self.completion_triggers
}
pub fn newline_style(&self) -> NewlineStyle {
self.newline_style
pub fn line_ending(&self) -> LineEnding {
self.line_ending
}
}
@ -2537,11 +2537,11 @@ impl std::ops::SubAssign for IndentSize {
}
}
impl NewlineStyle {
fn from_proto(style: proto::NewlineStyle) -> Self {
impl LineEnding {
fn from_proto(style: proto::LineEnding) -> Self {
match style {
proto::NewlineStyle::Unix => Self::Unix,
proto::NewlineStyle::Windows => Self::Windows,
proto::LineEnding::Unix => Self::Unix,
proto::LineEnding::Windows => Self::Windows,
}
}
@ -2560,20 +2560,20 @@ impl NewlineStyle {
pub fn as_str(self) -> &'static str {
match self {
NewlineStyle::Unix => "\n",
NewlineStyle::Windows => "\r\n",
LineEnding::Unix => "\n",
LineEnding::Windows => "\r\n",
}
}
fn to_proto(self) -> proto::NewlineStyle {
fn to_proto(self) -> proto::LineEnding {
match self {
NewlineStyle::Unix => proto::NewlineStyle::Unix,
NewlineStyle::Windows => proto::NewlineStyle::Windows,
LineEnding::Unix => proto::LineEnding::Unix,
LineEnding::Windows => proto::LineEnding::Windows,
}
}
}
impl Default for NewlineStyle {
impl Default for LineEnding {
fn default() -> Self {
#[cfg(unix)]
return Self::Unix;

View File

@ -9,7 +9,7 @@ use rpc::proto;
use std::{ops::Range, sync::Arc};
use text::*;
pub use proto::{Buffer, BufferState, NewlineStyle, SelectionSet};
pub use proto::{Buffer, BufferState, LineEnding, SelectionSet};
pub fn serialize_operation(operation: &Operation) -> proto::Operation {
proto::Operation {

View File

@ -1,7 +1,7 @@
use anyhow::{anyhow, Result};
use fsevent::EventStream;
use futures::{Stream, StreamExt};
use language::NewlineStyle;
use language::LineEnding;
use smol::io::{AsyncReadExt, AsyncWriteExt};
use std::{
io,
@ -22,7 +22,7 @@ pub trait Fs: Send + Sync {
async fn remove_file(&self, path: &Path, options: RemoveOptions) -> Result<()>;
async fn open_sync(&self, path: &Path) -> Result<Box<dyn io::Read>>;
async fn load(&self, path: &Path) -> Result<String>;
async fn save(&self, path: &Path, text: &Rope, newline_style: NewlineStyle) -> Result<()>;
async fn save(&self, path: &Path, text: &Rope, line_ending: LineEnding) -> Result<()>;
async fn canonicalize(&self, path: &Path) -> Result<PathBuf>;
async fn is_file(&self, path: &Path) -> bool;
async fn metadata(&self, path: &Path) -> Result<Option<Metadata>>;
@ -170,7 +170,7 @@ impl Fs for RealFs {
Ok(text)
}
async fn save(&self, path: &Path, text: &Rope, newline_style: NewlineStyle) -> Result<()> {
async fn save(&self, path: &Path, text: &Rope, line_ending: LineEnding) -> Result<()> {
let buffer_size = text.summary().bytes.min(10 * 1024);
let file = smol::fs::File::create(path).await?;
let mut writer = smol::io::BufWriter::with_capacity(buffer_size, file);
@ -178,7 +178,7 @@ impl Fs for RealFs {
for chunk in text.chunks() {
for line in chunk.split('\n') {
if newline {
writer.write_all(newline_style.as_str().as_bytes()).await?;
writer.write_all(line_ending.as_str().as_bytes()).await?;
}
writer.write_all(line.as_bytes()).await?;
newline = true;
@ -654,7 +654,7 @@ impl Fs for FakeFs {
Ok(text.clone())
}
async fn save(&self, path: &Path, text: &Rope, newline_style: NewlineStyle) -> Result<()> {
async fn save(&self, path: &Path, text: &Rope, line_ending: LineEnding) -> Result<()> {
self.simulate_random_delay().await;
let mut state = self.state.lock().await;
let path = normalize_path(path);
@ -665,7 +665,7 @@ impl Fs for FakeFs {
} else {
entry.content = Some(
text.chunks()
.map(|chunk| chunk.replace('\n', newline_style.as_str()))
.map(|chunk| chunk.replace('\n', line_ending.as_str()))
.collect(),
);
entry.metadata.mtime = SystemTime::now();

View File

@ -4,7 +4,7 @@ use futures::{future, StreamExt};
use gpui::{executor::Deterministic, test::subscribe};
use language::{
tree_sitter_rust, tree_sitter_typescript, Diagnostic, FakeLspAdapter, LanguageConfig,
NewlineStyle, OffsetRangeExt, Point, ToPoint,
LineEnding, OffsetRangeExt, Point, ToPoint,
};
use lsp::Url;
use serde_json::json;
@ -2429,7 +2429,7 @@ async fn test_buffer_file_changes_on_disk(cx: &mut gpui::TestAppContext) {
fs.save(
"/dir/the-file".as_ref(),
&new_contents.into(),
NewlineStyle::Unix,
LineEnding::Unix,
)
.await
.unwrap();
@ -2464,7 +2464,7 @@ async fn test_buffer_file_changes_on_disk(cx: &mut gpui::TestAppContext) {
fs.save(
"/dir/the-file".as_ref(),
&"\n\n\nAAAA\naaa\nBB\nbbbbb\n".into(),
NewlineStyle::Unix,
LineEnding::Unix,
)
.await
.unwrap();
@ -2501,11 +2501,11 @@ async fn test_buffer_line_endings(cx: &mut gpui::TestAppContext) {
buffer1.read_with(cx, |buffer, _| {
assert_eq!(buffer.text(), "a\nb\nc\n");
assert_eq!(buffer.newline_style(), NewlineStyle::Unix);
assert_eq!(buffer.line_ending(), LineEnding::Unix);
});
buffer2.read_with(cx, |buffer, _| {
assert_eq!(buffer.text(), "one\ntwo\nthree\n");
assert_eq!(buffer.newline_style(), NewlineStyle::Windows);
assert_eq!(buffer.line_ending(), LineEnding::Windows);
});
// Change a file's line endings on disk from unix to windows. The buffer's
@ -2513,14 +2513,14 @@ async fn test_buffer_line_endings(cx: &mut gpui::TestAppContext) {
fs.save(
"/dir/file1".as_ref(),
&"aaa\nb\nc\n".into(),
NewlineStyle::Windows,
LineEnding::Windows,
)
.await
.unwrap();
cx.foreground().run_until_parked();
buffer1.read_with(cx, |buffer, _| {
assert_eq!(buffer.text(), "aaa\nb\nc\n");
assert_eq!(buffer.newline_style(), NewlineStyle::Windows);
assert_eq!(buffer.line_ending(), LineEnding::Windows);
});
// Save a file with windows line endings. The file is written correctly.

View File

@ -24,7 +24,7 @@ use gpui::{
};
use language::{
proto::{deserialize_version, serialize_version},
Buffer, DiagnosticEntry, NewlineStyle, PointUtf16, Rope,
Buffer, DiagnosticEntry, LineEnding, PointUtf16, Rope,
};
use lazy_static::lazy_static;
use parking_lot::Mutex;
@ -595,7 +595,7 @@ impl LocalWorktree {
let text = buffer.as_rope().clone();
let fingerprint = text.fingerprint();
let version = buffer.version();
let save = self.write_file(path, text, buffer.newline_style(), cx);
let save = self.write_file(path, text, buffer.line_ending(), cx);
let handle = cx.handle();
cx.as_mut().spawn(|mut cx| async move {
let entry = save.await?;
@ -636,10 +636,10 @@ impl LocalWorktree {
&self,
path: impl Into<Arc<Path>>,
text: Rope,
newline_style: NewlineStyle,
line_ending: LineEnding,
cx: &mut ModelContext<Worktree>,
) -> Task<Result<Entry>> {
self.write_entry_internal(path, Some((text, newline_style)), cx)
self.write_entry_internal(path, Some((text, line_ending)), cx)
}
pub fn delete_entry(
@ -755,7 +755,7 @@ impl LocalWorktree {
fn write_entry_internal(
&self,
path: impl Into<Arc<Path>>,
text_if_file: Option<(Rope, NewlineStyle)>,
text_if_file: Option<(Rope, LineEnding)>,
cx: &mut ModelContext<Worktree>,
) -> Task<Result<Entry>> {
let path = path.into();
@ -764,8 +764,8 @@ impl LocalWorktree {
let fs = self.fs.clone();
let abs_path = abs_path.clone();
async move {
if let Some((text, newline_style)) = text_if_file {
fs.save(&abs_path, &text, newline_style).await
if let Some((text, line_ending)) = text_if_file {
fs.save(&abs_path, &text, line_ending).await
} else {
fs.create_dir(&abs_path).await
}
@ -1654,7 +1654,7 @@ impl language::File for File {
buffer_id: u64,
text: Rope,
version: clock::Global,
newline_style: NewlineStyle,
line_ending: LineEnding,
cx: &mut MutableAppContext,
) -> Task<Result<(clock::Global, String, SystemTime)>> {
self.worktree.update(cx, |worktree, cx| match worktree {
@ -1662,7 +1662,7 @@ impl language::File for File {
let rpc = worktree.client.clone();
let project_id = worktree.share.as_ref().map(|share| share.project_id);
let fingerprint = text.fingerprint();
let save = worktree.write_file(self.path.clone(), text, newline_style, cx);
let save = worktree.write_file(self.path.clone(), text, line_ending, cx);
cx.background().spawn(async move {
let entry = save.await?;
if let Some(project_id) = project_id {

View File

@ -810,10 +810,10 @@ message BufferState {
repeated Diagnostic diagnostics = 6;
uint32 diagnostics_timestamp = 7;
repeated string completion_triggers = 8;
NewlineStyle newline_style = 9;
LineEnding line_ending = 9;
}
enum NewlineStyle {
enum LineEnding {
Unix = 0;
Windows = 1;
}