From e47728b935bae8615b6fb5cdddd271597c3e5db6 Mon Sep 17 00:00:00 2001 From: Yacin Tmimi Date: Wed, 17 Aug 2022 13:13:25 -0400 Subject: [PATCH] Don't duplicate line numbers when annotating internal errors Closes 5463 The `annotate_snippets` crate adds line number and column info to the output, so we don't need to append the line number to the `origin`. Previously, internal errors would be output with the line number twice. See how 478 is duplicated in the example below. ``` error[internal]: line formatted, but exceeded maximum width --> /path/to/file.rs:478:478:101 ``` Now the line number is not duplicated. ``` error[internal]: line formatted, but exceeded maximum width --> /path/to/file.rs:478:101 ``` --- src/format_report_formatter.rs | 2 +- src/formatting.rs | 29 +++++++++++++++++++++++++++++ 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/src/format_report_formatter.rs b/src/format_report_formatter.rs index fd536d4df41..9c744b8e2ef 100644 --- a/src/format_report_formatter.rs +++ b/src/format_report_formatter.rs @@ -78,7 +78,7 @@ impl<'a> Display for FormatReportFormatter<'a> { None }; - let origin = format!("{}:{}", file, error.line); + let origin = file.to_string(); let slice = Slice { source: &error.line_buffer.clone(), line_start: error.line, diff --git a/src/formatting.rs b/src/formatting.rs index cd57a025b67..dd13a28f704 100644 --- a/src/formatting.rs +++ b/src/formatting.rs @@ -645,3 +645,32 @@ where f(); } } + +#[cfg(test)] +mod test { + use std::path::PathBuf; + + use crate::FormatReportFormatterBuilder; + + use super::*; + + #[test] + fn test_internal_error_file_and_line_number_annotations() { + let mut config = Config::default(); + config.set().error_on_unformatted(true); + + let mut text = String::new(); + text.push_str("fn main() {\n"); + text.push_str(" println!(\"hello world!\"); \n"); // Note the space before the '\n' + text.push_str("}"); + + let report = FormatReport::new(); + let name = FileName::Real(PathBuf::from("internal_error_test.rs")); + + format_lines(&mut text, &name, &vec![], &config, &report); + let output = FormatReportFormatterBuilder::new(&report) + .build() + .to_string(); + assert!(output.contains("--> internal_error_test.rs:2:30")); + } +}