diff --git a/crates/ruff/src/checkers/noqa.rs b/crates/ruff/src/checkers/noqa.rs index 2733ca0605527..16cea1d7cb82f 100644 --- a/crates/ruff/src/checkers/noqa.rs +++ b/crates/ruff/src/checkers/noqa.rs @@ -23,7 +23,7 @@ pub(crate) fn check_noqa( settings: &Settings, ) -> Vec { // Identify any codes that are globally exempted (within the current file). - let exemption = FileExemption::try_extract(locator.contents(), comment_ranges); + let exemption = FileExemption::try_extract(locator.contents(), comment_ranges, locator); // Extract all `noqa` directives. let mut noqa_directives = NoqaDirectives::from_commented_ranges(comment_ranges, locator); diff --git a/crates/ruff/src/noqa.rs b/crates/ruff/src/noqa.rs index a34b73f57c6a3..4f015ed268871 100644 --- a/crates/ruff/src/noqa.rs +++ b/crates/ruff/src/noqa.rs @@ -1,4 +1,5 @@ use std::collections::BTreeMap; +use std::error::Error; use std::fmt::{Display, Write}; use std::fs; use std::ops::Add; @@ -39,7 +40,7 @@ pub(crate) enum Directive<'a> { impl<'a> Directive<'a> { /// Extract the noqa `Directive` from a line of Python source code. - pub(crate) fn try_extract(text: &'a str, offset: TextSize) -> Option { + pub(crate) fn try_extract(text: &'a str, offset: TextSize) -> Result, ParseError> { for mat in NOQA_MATCHER.find_iter(text) { let noqa_literal_start = mat.start(); @@ -62,7 +63,7 @@ impl<'a> Directive<'a> { // If the next character is `:`, then it's a list of codes. Otherwise, it's a directive // to ignore all rules. let noqa_literal_end = mat.end(); - return Some( + return Ok(Some( if text[noqa_literal_end..] .chars() .next() @@ -100,6 +101,11 @@ impl<'a> Directive<'a> { } } + // If we didn't identify any codes, warn. + if codes.is_empty() { + return Err(ParseError::MissingCodes); + } + let range = TextRange::new( TextSize::try_from(comment_start).unwrap(), TextSize::try_from(codes_end).unwrap(), @@ -119,10 +125,10 @@ impl<'a> Directive<'a> { range: range.add(offset), }) }, - ); + )); } - None + Ok(None) } /// Lex an individual rule code (e.g., `F401`). @@ -194,9 +200,9 @@ pub(crate) fn rule_is_ignored( let offset = noqa_line_for.resolve(offset); let line_range = locator.line_range(offset); match Directive::try_extract(locator.slice(line_range), line_range.start()) { - Some(Directive::All(_)) => true, - Some(Directive::Codes(Codes { codes, range: _ })) => includes(code, &codes), - None => false, + Ok(Some(Directive::All(_))) => true, + Ok(Some(Directive::Codes(Codes { codes, range: _ }))) => includes(code, &codes), + _ => false, } } @@ -212,26 +218,37 @@ pub(crate) enum FileExemption { impl FileExemption { /// Extract the [`FileExemption`] for a given Python source file, enumerating any rules that are /// globally ignored within the file. - pub(crate) fn try_extract(contents: &str, comment_ranges: &[TextRange]) -> Option { + pub(crate) fn try_extract( + contents: &str, + comment_ranges: &[TextRange], + locator: &Locator, + ) -> Option { let mut exempt_codes: Vec = vec![]; for range in comment_ranges { match ParsedFileExemption::try_extract(&contents[*range]) { - Some(ParsedFileExemption::All) => { + Err(err) => { + #[allow(deprecated)] + let line = locator.compute_line_index(range.start()); + warn!("Invalid `# noqa` directive on line {line}: {err}"); + } + Ok(Some(ParsedFileExemption::All)) => { return Some(Self::All); } - Some(ParsedFileExemption::Codes(codes)) => { + Ok(Some(ParsedFileExemption::Codes(codes))) => { exempt_codes.extend(codes.into_iter().filter_map(|code| { if let Ok(rule) = Rule::from_code(get_redirect_target(code).unwrap_or(code)) { Some(rule.noqa_code()) } else { - warn!("Invalid code provided to `# ruff: noqa`: {}", code); + #[allow(deprecated)] + let line = locator.compute_line_index(range.start()); + warn!("Invalid code provided to `# ruff: noqa` on line {line}: {code}"); None } })); } - None => {} + Ok(None) => {} } } @@ -256,33 +273,51 @@ enum ParsedFileExemption<'a> { impl<'a> ParsedFileExemption<'a> { /// Return a [`ParsedFileExemption`] for a given comment line. - fn try_extract(line: &'a str) -> Option { + fn try_extract(line: &'a str) -> Result, ParseError> { let line = Self::lex_whitespace(line); - let line = Self::lex_char(line, '#')?; + let Some(line) = Self::lex_char(line, '#') else { + return Ok(None); + }; let line = Self::lex_whitespace(line); if let Some(line) = Self::lex_flake8(line) { // Ex) `# flake8: noqa` let line = Self::lex_whitespace(line); - let line = Self::lex_char(line, ':')?; + let Some(line) = Self::lex_char(line, ':') else { + return Ok(None); + }; + let line = Self::lex_whitespace(line); + let Some(line) = Self::lex_noqa(line) else { + return Ok(None); + }; + + // Guard against, e.g., `# flake8: noqa: F401`, which isn't supported by Flake8. + // Flake8 treats this as a blanket exemption, which is almost never the intent. + // Warn, but treat as a blanket exemption. let line = Self::lex_whitespace(line); - Self::lex_noqa(line)?; - Some(Self::All) + if Self::lex_char(line, ':').is_some() { + return Err(ParseError::UnsupportedCodes); + } + + Ok(Some(Self::All)) } else if let Some(line) = Self::lex_ruff(line) { let line = Self::lex_whitespace(line); - let line = Self::lex_char(line, ':')?; + let Some(line) = Self::lex_char(line, ':') else { + return Ok(None); + }; + let line = Self::lex_whitespace(line); + let Some(line) = Self::lex_noqa(line) else { + return Ok(None); + }; let line = Self::lex_whitespace(line); - let line = Self::lex_noqa(line)?; - if line.is_empty() { + Ok(Some(if line.is_empty() { // Ex) `# ruff: noqa` - Some(Self::All) + Self::All } else { // Ex) `# ruff: noqa: F401, F841` - let line = Self::lex_whitespace(line); let Some(line) = Self::lex_char(line, ':') else { - warn!("Unexpected suffix on `noqa` directive: \"{line}\""); - return None; + return Err(ParseError::InvalidSuffix); }; let line = Self::lex_whitespace(line); @@ -301,10 +336,15 @@ impl<'a> ParsedFileExemption<'a> { } } - Some(Self::Codes(codes)) - } + // If we didn't identify any codes, warn. + if codes.is_empty() { + return Err(ParseError::MissingCodes); + } + + Self::Codes(codes) + })) } else { - None + Ok(None) } } @@ -380,6 +420,34 @@ impl<'a> ParsedFileExemption<'a> { } } +/// The result of an [`Importer::get_or_import_symbol`] call. +#[derive(Debug)] +pub(crate) enum ParseError { + /// The `noqa` directive was missing valid codes (e.g., `# noqa: unused-import` instead of `# noqa: F401`). + MissingCodes, + /// The `noqa` directive used an invalid suffix (e.g., `# noqa; F401` instead of `# noqa: F401`). + InvalidSuffix, + /// The `noqa` directive attempted to exempt specific codes in an unsupported location (e.g., + /// `# flake8: noqa: F401, F841` instead of `# ruff: noqa: F401, F841`). + UnsupportedCodes, +} + +impl Display for ParseError { + fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + match self { + ParseError::MissingCodes => fmt.write_str("expected a comma-separated list of codes (e.g., `# noqa: F401, F841`)."), + ParseError::InvalidSuffix => { + fmt.write_str("expected `:` followed by a comma-separated list of codes (e.g., `# noqa: F401, F841`).") + } + ParseError::UnsupportedCodes => { + fmt.write_str("Flake8's blanket exemption does not support exempting specific codes. To exempt specific codes, use, e.g., `# ruff: noqa: F401, F841` instead.") + } + } + } +} + +impl Error for ParseError {} + /// Adds noqa comments to suppress all diagnostics of a file. pub(crate) fn add_noqa( path: &Path, @@ -413,7 +481,7 @@ fn add_noqa_inner( // Whether the file is exempted from all checks. // Codes that are globally exempted (within the current file). - let exemption = FileExemption::try_extract(locator.contents(), commented_ranges); + let exemption = FileExemption::try_extract(locator.contents(), commented_ranges, locator); let directives = NoqaDirectives::from_commented_ranges(commented_ranges, locator); // Mark any non-ignored diagnostics. @@ -583,14 +651,22 @@ impl<'a> NoqaDirectives<'a> { let mut directives = Vec::new(); for range in comment_ranges { - if let Some(directive) = Directive::try_extract(locator.slice(*range), range.start()) { - // noqa comments are guaranteed to be single line. - directives.push(NoqaDirectiveLine { - range: locator.line_range(range.start()), - directive, - matches: Vec::new(), - }); - }; + match Directive::try_extract(locator.slice(*range), range.start()) { + Err(err) => { + #[allow(deprecated)] + let line = locator.compute_line_index(range.start()); + warn!("Invalid `# noqa` directive on line {line}: {err}"); + } + Ok(Some(directive)) => { + // noqa comments are guaranteed to be single line. + directives.push(NoqaDirectiveLine { + range: locator.line_range(range.start()), + directive, + matches: Vec::new(), + }); + } + Ok(None) => {} + } } // Extend a mapping at the end of the file to also include the EOF token. @@ -836,7 +912,7 @@ mod tests { #[test] fn noqa_invalid_codes() { - let source = "# noqa: F401, unused-import, some other code"; + let source = "# noqa: unused-import, F401, some other code"; assert_debug_snapshot!(Directive::try_extract(source, TextSize::default())); } diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all.snap index 30642fbd1c503..55b08ffd6fc9e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all.snap @@ -2,6 +2,8 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Ok( + Some( + All, + ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_case_insensitive.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_case_insensitive.snap index 30642fbd1c503..55b08ffd6fc9e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_case_insensitive.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_case_insensitive.snap @@ -2,6 +2,8 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Ok( + Some( + All, + ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_no_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_no_space.snap index 30642fbd1c503..55b08ffd6fc9e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_no_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_all_no_space.snap @@ -2,6 +2,8 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Ok( + Some( + All, + ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_codes.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_codes.snap index 30642fbd1c503..9b5fede6df940 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_codes.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__flake8_exemption_codes.snap @@ -2,6 +2,6 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Err( + UnsupportedCodes, ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all.snap index 6d5ffa6fd83c2..806987e18b513 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all.snap @@ -1,11 +1,13 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - All( - All { - range: 0..6, - }, +Ok( + Some( + All( + All { + range: 0..6, + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_case_insensitive.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_case_insensitive.snap index 6d5ffa6fd83c2..806987e18b513 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_case_insensitive.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_case_insensitive.snap @@ -1,11 +1,13 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - All( - All { - range: 0..6, - }, +Ok( + Some( + All( + All { + range: 0..6, + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_leading_comment.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_leading_comment.snap index e05a6cbb9dea5..bd4fea2744f5c 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_leading_comment.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_leading_comment.snap @@ -2,10 +2,12 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - All( - All { - range: 35..41, - }, +Ok( + Some( + All( + All { + range: 35..41, + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_multi_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_multi_space.snap index a7a81d2752239..b7fa476cc1247 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_multi_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_multi_space.snap @@ -2,10 +2,12 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - All( - All { - range: 0..7, - }, +Ok( + Some( + All( + All { + range: 0..7, + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_no_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_no_space.snap index a6504f2ee0874..b5dcc889b87a5 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_no_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_no_space.snap @@ -2,10 +2,12 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - All( - All { - range: 0..5, - }, +Ok( + Some( + All( + All { + range: 0..5, + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_trailing_comment.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_trailing_comment.snap index 528d99278f154..806987e18b513 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_trailing_comment.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_all_trailing_comment.snap @@ -2,10 +2,12 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - All( - All { - range: 0..6, - }, +Ok( + Some( + All( + All { + range: 0..6, + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code.snap index fd0bc5502df6e..bee06c0364686 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code.snap @@ -1,14 +1,16 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..12, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..12, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_case_insensitive.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_case_insensitive.snap index fd0bc5502df6e..bee06c0364686 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_case_insensitive.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_case_insensitive.snap @@ -1,14 +1,16 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..12, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..12, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_leading_comment.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_leading_comment.snap index 1132885227c16..4577119d5759e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_leading_comment.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_leading_comment.snap @@ -2,13 +2,15 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 35..47, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 35..47, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_multi_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_multi_space.snap index e08e9a849a96c..4b6104870faa8 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_multi_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_multi_space.snap @@ -2,13 +2,15 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..13, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..13, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_no_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_no_space.snap index 7c07294cc738d..5f3e8124ff4a1 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_no_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_no_space.snap @@ -2,13 +2,15 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..10, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..10, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_trailing_comment.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_trailing_comment.snap index ff3293f0afc33..bee06c0364686 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_trailing_comment.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_code_trailing_comment.snap @@ -2,13 +2,15 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..12, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..12, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes.snap index 61c78604a1d14..65e429c7af4ed 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes.snap @@ -1,15 +1,17 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..18, - codes: [ - "F401", - "F841", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..18, + codes: [ + "F401", + "F841", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_case_insensitive.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_case_insensitive.snap index 61c78604a1d14..65e429c7af4ed 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_case_insensitive.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_case_insensitive.snap @@ -1,15 +1,17 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..18, - codes: [ - "F401", - "F841", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..18, + codes: [ + "F401", + "F841", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_leading_comment.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_leading_comment.snap index d771ab548ea1d..9f72b14ab05dd 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_leading_comment.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_leading_comment.snap @@ -2,14 +2,16 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 35..53, - codes: [ - "F401", - "F841", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 35..53, + codes: [ + "F401", + "F841", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_multi_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_multi_space.snap index e76c0a28fdb64..c4e9c8643c06f 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_multi_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_multi_space.snap @@ -2,14 +2,16 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..20, - codes: [ - "F401", - "F841", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..20, + codes: [ + "F401", + "F841", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_no_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_no_space.snap index 6c16281542a55..4c699e253fc51 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_no_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_no_space.snap @@ -2,14 +2,16 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..15, - codes: [ - "F401", - "F841", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..15, + codes: [ + "F401", + "F841", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_trailing_comment.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_trailing_comment.snap index da2e044c731d9..65e429c7af4ed 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_trailing_comment.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_codes_trailing_comment.snap @@ -2,14 +2,16 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..18, - codes: [ - "F401", - "F841", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..18, + codes: [ + "F401", + "F841", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_invalid_codes.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_invalid_codes.snap index ff3293f0afc33..deb779531446a 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_invalid_codes.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_invalid_codes.snap @@ -2,13 +2,6 @@ source: crates/ruff/src/noqa.rs expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..12, - codes: [ - "F401", - ], - }, - ), +Err( + MissingCodes, ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_leading_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_leading_space.snap index 85081b1a53e2c..47f626e011e95 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_leading_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_leading_space.snap @@ -1,14 +1,16 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 4..16, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 4..16, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_trailing_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_trailing_space.snap index fd0bc5502df6e..bee06c0364686 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_trailing_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__noqa_trailing_space.snap @@ -1,14 +1,16 @@ --- source: crates/ruff/src/noqa.rs -expression: "Directive::try_extract(range, &locator)" +expression: "Directive::try_extract(source, TextSize::default())" --- -Some( - Codes( - Codes { - range: 0..12, - codes: [ - "F401", - ], - }, +Ok( + Some( + Codes( + Codes { + range: 0..12, + codes: [ + "F401", + ], + }, + ), ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all.snap index 30642fbd1c503..55b08ffd6fc9e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all.snap @@ -2,6 +2,8 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Ok( + Some( + All, + ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_case_insensitive.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_case_insensitive.snap index 30642fbd1c503..55b08ffd6fc9e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_case_insensitive.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_case_insensitive.snap @@ -2,6 +2,8 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Ok( + Some( + All, + ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_no_space.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_no_space.snap index 30642fbd1c503..55b08ffd6fc9e 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_no_space.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_all_no_space.snap @@ -2,6 +2,8 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - All, +Ok( + Some( + All, + ), ) diff --git a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_codes.snap b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_codes.snap index cbf46f63ff3dd..b45c9ca1ae473 100644 --- a/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_codes.snap +++ b/crates/ruff/src/snapshots/ruff__noqa__tests__ruff_exemption_codes.snap @@ -2,11 +2,13 @@ source: crates/ruff/src/noqa.rs expression: "ParsedFileExemption::try_extract(source)" --- -Some( - Codes( - [ - "F401", - "F841", - ], +Ok( + Some( + Codes( + [ + "F401", + "F841", + ], + ), ), )