From c49d5f757cccc7fc2ef02f6a8b3cf8a459c8f326 Mon Sep 17 00:00:00 2001 From: Jesse Bakker Date: Tue, 5 Jan 2021 22:29:53 +0100 Subject: [PATCH] Normalize line endings when formatting --- crates/rust-analyzer/src/handlers.rs | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/crates/rust-analyzer/src/handlers.rs b/crates/rust-analyzer/src/handlers.rs index dd486070b91..3e49904c337 100644 --- a/crates/rust-analyzer/src/handlers.rs +++ b/crates/rust-analyzer/src/handlers.rs @@ -31,12 +31,13 @@ use stdx::{format_to, split_once}; use syntax::{algo, ast, AstNode, TextRange, TextSize}; -use crate::diff::diff; use crate::{ cargo_target_spec::CargoTargetSpec, config::RustfmtConfig, + diff::diff, from_json, from_proto, global_state::{GlobalState, GlobalStateSnapshot}, + line_endings::LineEndings, lsp_ext::{self, InlayHint, InlayHintsParams}, lsp_utils::all_edits_are_disjoint, to_proto, LspError, Result, @@ -909,14 +910,25 @@ pub(crate) fn handle_formatting( } } - if *file == captured_stdout { + let (new_text, new_line_endings) = LineEndings::normalize(captured_stdout); + + if file_line_endings != new_line_endings { + // If line endings are different, send the entire file. + // Diffing would not work here, as the line endings might be the only + // difference. + Ok(Some(to_proto::text_edit_vec( + &file_line_index, + new_line_endings, + TextEdit::replace(TextRange::up_to(TextSize::of(&*file)), new_text), + ))) + } else if *file == new_text { // The document is already formatted correctly -- no edits needed. Ok(None) } else { Ok(Some(to_proto::text_edit_vec( &file_line_index, file_line_endings, - diff(&file, &captured_stdout), + diff(&file, &new_text), ))) } }