From c531897a892843ef0d301dd483e352db0b6bbc5f Mon Sep 17 00:00:00 2001 From: Dhruv Manilawala Date: Mon, 17 Jun 2024 16:47:49 +0530 Subject: [PATCH] Avoid displaying syntax error as log message --- crates/ruff/src/diagnostics.rs | 139 +++++++++++--------------- crates/ruff/tests/integration_test.rs | 3 - crates/ruff_linter/src/linter.rs | 18 +--- 3 files changed, 60 insertions(+), 100 deletions(-) diff --git a/crates/ruff/src/diagnostics.rs b/crates/ruff/src/diagnostics.rs index db24952b7a70fb..e857d29c3d3075 100644 --- a/crates/ruff/src/diagnostics.rs +++ b/crates/ruff/src/diagnostics.rs @@ -9,13 +9,12 @@ use std::path::Path; use anyhow::{Context, Result}; use colored::Colorize; -use log::{debug, error, warn}; -use ruff_linter::codes::Rule; +use log::{debug, warn}; use rustc_hash::FxHashMap; use ruff_diagnostics::Diagnostic; +use ruff_linter::codes::Rule; use ruff_linter::linter::{lint_fix, lint_only, FixTable, FixerResult, LinterResult, ParseSource}; -use ruff_linter::logging::DisplayParseError; use ruff_linter::message::{Message, SyntaxErrorMessage}; use ruff_linter::pyproject_toml::lint_pyproject_toml; use ruff_linter::settings::types::UnsafeFixes; @@ -357,13 +356,6 @@ pub(crate) fn lint_path( } } - if let Some(error) = parse_error { - error!( - "{}", - DisplayParseError::from_source_kind(error, Some(path.to_path_buf()), &transformed) - ); - } - let notebook_indexes = if let SourceKind::IpyNotebook(notebook) = transformed { FxHashMap::from_iter([(path.to_string_lossy().to_string(), notebook.into_index())]) } else { @@ -408,52 +400,66 @@ pub(crate) fn lint_stdin( }; // Lint the inputs. - let ( - LinterResult { - data: messages, - error: parse_error, - }, - transformed, - fixed, - ) = if matches!(fix_mode, flags::FixMode::Apply | flags::FixMode::Diff) { - if let Ok(FixerResult { - result, - transformed, - fixed, - }) = lint_fix( - path.unwrap_or_else(|| Path::new("-")), - package, - noqa, - settings.unsafe_fixes, - &settings.linter, - &source_kind, - source_type, - ) { - match fix_mode { - flags::FixMode::Apply => { - // Write the contents to stdout, regardless of whether any errors were fixed. - transformed.write(&mut io::stdout().lock())?; - } - flags::FixMode::Diff => { - // But only write a diff if it's non-empty. - if !fixed.is_empty() { - write!( - &mut io::stdout().lock(), - "{}", - source_kind.diff(&transformed, path).unwrap() - )?; + let (LinterResult { data: messages, .. }, transformed, fixed) = + if matches!(fix_mode, flags::FixMode::Apply | flags::FixMode::Diff) { + if let Ok(FixerResult { + result, + transformed, + fixed, + }) = lint_fix( + path.unwrap_or_else(|| Path::new("-")), + package, + noqa, + settings.unsafe_fixes, + &settings.linter, + &source_kind, + source_type, + ) { + match fix_mode { + flags::FixMode::Apply => { + // Write the contents to stdout, regardless of whether any errors were fixed. + transformed.write(&mut io::stdout().lock())?; + } + flags::FixMode::Diff => { + // But only write a diff if it's non-empty. + if !fixed.is_empty() { + write!( + &mut io::stdout().lock(), + "{}", + source_kind.diff(&transformed, path).unwrap() + )?; + } } + flags::FixMode::Generate => {} } - flags::FixMode::Generate => {} - } - let transformed = if let Cow::Owned(transformed) = transformed { - transformed + let transformed = if let Cow::Owned(transformed) = transformed { + transformed + } else { + source_kind + }; + (result, transformed, fixed) } else { - source_kind - }; - (result, transformed, fixed) + // If we fail to fix, lint the original source code. + let result = lint_only( + path.unwrap_or_else(|| Path::new("-")), + package, + &settings.linter, + noqa, + &source_kind, + source_type, + ParseSource::None, + ); + + // Write the contents to stdout anyway. + if fix_mode.is_apply() { + source_kind.write(&mut io::stdout().lock())?; + } + + let transformed = source_kind; + let fixed = FxHashMap::default(); + (result, transformed, fixed) + } } else { - // If we fail to fix, lint the original source code. let result = lint_only( path.unwrap_or_else(|| Path::new("-")), package, @@ -463,37 +469,10 @@ pub(crate) fn lint_stdin( source_type, ParseSource::None, ); - - // Write the contents to stdout anyway. - if fix_mode.is_apply() { - source_kind.write(&mut io::stdout().lock())?; - } - let transformed = source_kind; let fixed = FxHashMap::default(); (result, transformed, fixed) - } - } else { - let result = lint_only( - path.unwrap_or_else(|| Path::new("-")), - package, - &settings.linter, - noqa, - &source_kind, - source_type, - ParseSource::None, - ); - let transformed = source_kind; - let fixed = FxHashMap::default(); - (result, transformed, fixed) - }; - - if let Some(error) = parse_error { - error!( - "{}", - DisplayParseError::from_source_kind(error, path.map(Path::to_path_buf), &transformed) - ); - } + }; let notebook_indexes = if let SourceKind::IpyNotebook(notebook) = transformed { FxHashMap::from_iter([( diff --git a/crates/ruff/tests/integration_test.rs b/crates/ruff/tests/integration_test.rs index 0708d60d932923..99e93f24639632 100644 --- a/crates/ruff/tests/integration_test.rs +++ b/crates/ruff/tests/integration_test.rs @@ -807,7 +807,6 @@ fn stdin_parse_error() { Found 1 error. ----- stderr ----- - error: Failed to parse at 1:16: Expected one or more symbol names after import "###); } @@ -836,7 +835,6 @@ fn stdin_multiple_parse_error() { Found 2 errors. ----- stderr ----- - error: Failed to parse at 1:16: Expected one or more symbol names after import "###); } @@ -858,7 +856,6 @@ fn parse_error_not_included() { Found 1 error. ----- stderr ----- - error: Failed to parse at 1:6: Expected an expression "###); } diff --git a/crates/ruff_linter/src/linter.rs b/crates/ruff_linter/src/linter.rs index bc97ac87e62ca8..37d7e75df38978 100644 --- a/crates/ruff_linter/src/linter.rs +++ b/crates/ruff_linter/src/linter.rs @@ -5,7 +5,6 @@ use std::path::Path; use anyhow::{anyhow, Result}; use colored::Colorize; use itertools::Itertools; -use log::error; use rustc_hash::FxHashMap; use ruff_diagnostics::Diagnostic; @@ -26,7 +25,6 @@ use crate::checkers::tokens::check_tokens; use crate::directives::Directives; use crate::doc_lines::{doc_lines_from_ast, doc_lines_from_tokens}; use crate::fix::{fix_file, FixResult}; -use crate::logging::DisplayParseError; use crate::message::Message; use crate::noqa::add_noqa; use crate::registry::{AsRule, Rule, RuleSet}; @@ -354,8 +352,7 @@ pub fn add_noqa_to_path( // Generate diagnostics, ignoring any existing `noqa` directives. let LinterResult { - data: diagnostics, - error, + data: diagnostics, .. } = check_path( path, package, @@ -370,19 +367,6 @@ pub fn add_noqa_to_path( &parsed, ); - // Log any parse errors. - if let Some(error) = error { - error!( - "{}", - DisplayParseError::from_source_code( - error, - Some(path.to_path_buf()), - &locator.to_source_code(), - source_kind, - ) - ); - } - // Add any missing `# noqa` pragmas. // TODO(dhruvmanila): Add support for Jupyter Notebooks add_noqa(