1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-15 02:20:15 -05:00

refactor(lint): show hint for lint errors (#8016)

This commit adds formatting of optional "hint" that
can be present in lint diagnostic.
This commit is contained in:
Bartek Iwańczuk 2020-10-18 16:26:05 +02:00 committed by GitHub
parent b33e8d5d42
commit 8f9da368f7
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 21 additions and 6 deletions

View file

@ -222,6 +222,7 @@ impl LintReporter for PrettyLintReporter {
&pretty_message, &pretty_message,
&source_lines, &source_lines,
d.range.clone(), d.range.clone(),
d.hint.as_ref(),
&fmt_errors::format_location(&JsStackFrame::from_location( &fmt_errors::format_location(&JsStackFrame::from_location(
Some(d.filename.clone()), Some(d.filename.clone()),
Some(d.range.start.line as i64), Some(d.range.start.line as i64),
@ -256,6 +257,7 @@ pub fn format_diagnostic(
message_line: &str, message_line: &str,
source_lines: &[&str], source_lines: &[&str],
range: deno_lint::diagnostic::Range, range: deno_lint::diagnostic::Range,
maybe_hint: Option<&String>,
formatted_location: &str, formatted_location: &str,
) -> String { ) -> String {
let mut lines = vec![]; let mut lines = vec![];
@ -284,6 +286,16 @@ pub fn format_diagnostic(
} }
} }
if let Some(hint) = maybe_hint {
format!(
"{}\n{}\n at {}\n\n {} {}",
message_line,
lines.join("\n"),
formatted_location,
colors::gray("hint:"),
hint,
)
} else {
format!( format!(
"{}\n{}\n at {}", "{}\n{}\n at {}",
message_line, message_line,
@ -291,6 +303,7 @@ pub fn format_diagnostic(
formatted_location formatted_location
) )
} }
}
#[derive(Serialize)] #[derive(Serialize)]
struct JsonLintReporter { struct JsonLintReporter {

View file

@ -3,6 +3,8 @@
^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^
at [WILDCARD]file1.js:1:0 at [WILDCARD]file1.js:1:0
hint: [WILDCARD]
(no-empty) Empty block statement (no-empty) Empty block statement
while (false) {} while (false) {}
^^ ^^