From c6071fd5610eec1b7a761f1af9d9ea6321c1cae0 Mon Sep 17 00:00:00 2001 From: Charlie Marsh Date: Wed, 6 Mar 2024 22:29:10 -0500 Subject: [PATCH] Allow fixes for f-string rule regardless of line length --- .../src/checkers/ast/analyze/expression.rs | 2 +- crates/ruff_linter/src/fix/edits.rs | 23 -------- .../src/rules/pyupgrade/rules/f_strings.rs | 19 +------ ...__rules__pyupgrade__tests__UP032_0.py.snap | 53 +++++++++++++++++-- 4 files changed, 53 insertions(+), 44 deletions(-) diff --git a/crates/ruff_linter/src/checkers/ast/analyze/expression.rs b/crates/ruff_linter/src/checkers/ast/analyze/expression.rs index 375e5743efdcf..e3b7f0a777d22 100644 --- a/crates/ruff_linter/src/checkers/ast/analyze/expression.rs +++ b/crates/ruff_linter/src/checkers/ast/analyze/expression.rs @@ -427,7 +427,7 @@ pub(crate) fn expression(expr: &Expr, checker: &mut Checker) { pyupgrade::rules::format_literals(checker, call, &summary); } if checker.enabled(Rule::FString) { - pyupgrade::rules::f_strings(checker, call, &summary, value); + pyupgrade::rules::f_strings(checker, call, &summary); } } } diff --git a/crates/ruff_linter/src/fix/edits.rs b/crates/ruff_linter/src/fix/edits.rs index 7adf6b2bfdbc6..3e4ac1f3170e8 100644 --- a/crates/ruff_linter/src/fix/edits.rs +++ b/crates/ruff_linter/src/fix/edits.rs @@ -418,29 +418,6 @@ pub(crate) fn fits( all_lines_fit(fix, node, locator, line_length.value() as usize, tab_size) } -/// Returns `true` if the fix fits within the maximum configured line length, or produces lines that -/// are shorter than the maximum length of the existing AST node. -pub(crate) fn fits_or_shrinks( - fix: &str, - node: AnyNodeRef, - locator: &Locator, - line_length: LineLength, - tab_size: IndentWidth, -) -> bool { - // Use the larger of the line length limit, or the longest line in the existing AST node. - let line_length = std::iter::once(line_length.value() as usize) - .chain( - locator - .slice(locator.lines_range(node.range())) - .universal_newlines() - .map(|line| LineWidthBuilder::new(tab_size).add_str(&line).get()), - ) - .max() - .unwrap_or(line_length.value() as usize); - - all_lines_fit(fix, node, locator, line_length, tab_size) -} - /// Returns `true` if all lines in the fix are shorter than the given line length. fn all_lines_fit( fix: &str, diff --git a/crates/ruff_linter/src/rules/pyupgrade/rules/f_strings.rs b/crates/ruff_linter/src/rules/pyupgrade/rules/f_strings.rs index 30c1fdb829843..83788e5a9da0d 100644 --- a/crates/ruff_linter/src/rules/pyupgrade/rules/f_strings.rs +++ b/crates/ruff_linter/src/rules/pyupgrade/rules/f_strings.rs @@ -15,7 +15,6 @@ use ruff_source_file::Locator; use ruff_text_size::{Ranged, TextRange}; use crate::checkers::ast::Checker; -use crate::fix::edits::fits_or_shrinks; use crate::rules::pyflakes::format::FormatSummary; use crate::rules::pyupgrade::helpers::{curly_escape, curly_unescape}; @@ -343,12 +342,7 @@ fn try_convert_to_f_string( } /// UP032 -pub(crate) fn f_strings( - checker: &mut Checker, - call: &ast::ExprCall, - summary: &FormatSummary, - template: &Expr, -) { +pub(crate) fn f_strings(checker: &mut Checker, call: &ast::ExprCall, summary: &FormatSummary) { if summary.has_nested_parts { return; } @@ -468,15 +462,6 @@ pub(crate) fn f_strings( let mut diagnostic = Diagnostic::new(FString, call.range()); - // Avoid refactors that exceed the line length limit or make it exceed by more. - let f_string_fits_or_shrinks = fits_or_shrinks( - &contents, - template.into(), - checker.locator(), - checker.settings.pycodestyle.max_line_length, - checker.settings.tab_size, - ); - // Avoid fix if there are comments within the call: // ``` // "{}".format( @@ -488,7 +473,7 @@ pub(crate) fn f_strings( .comment_ranges() .intersects(call.arguments.range()); - if f_string_fits_or_shrinks && !has_comments { + if !has_comments { diagnostic.set_fix(Fix::safe_edit(Edit::range_replacement( contents, call.range(), diff --git a/crates/ruff_linter/src/rules/pyupgrade/snapshots/ruff_linter__rules__pyupgrade__tests__UP032_0.py.snap b/crates/ruff_linter/src/rules/pyupgrade/snapshots/ruff_linter__rules__pyupgrade__tests__UP032_0.py.snap index 305e2ee42f0dc..be53a7670d3d2 100644 --- a/crates/ruff_linter/src/rules/pyupgrade/snapshots/ruff_linter__rules__pyupgrade__tests__UP032_0.py.snap +++ b/crates/ruff_linter/src/rules/pyupgrade/snapshots/ruff_linter__rules__pyupgrade__tests__UP032_0.py.snap @@ -945,7 +945,7 @@ UP032_0.py:129:1: UP032 [*] Use f-string instead of `format` call 131 131 | ### 132 132 | # Non-errors -UP032_0.py:160:1: UP032 Use f-string instead of `format` call +UP032_0.py:160:1: UP032 [*] Use f-string instead of `format` call | 158 | r'"\N{snowman} {}".format(a)' 159 | @@ -958,7 +958,19 @@ UP032_0.py:160:1: UP032 Use f-string instead of `format` call | = help: Convert to f-string -UP032_0.py:164:1: UP032 Use f-string instead of `format` call +ℹ Safe fix +157 157 | +158 158 | r'"\N{snowman} {}".format(a)' +159 159 | +160 |-"123456789 {}".format( +161 |- 11111111111111111111111111111111111111111111111111111111111111111111111111, +162 |-) + 160 |+f"123456789 {11111111111111111111111111111111111111111111111111111111111111111111111111}" +163 161 | +164 162 | """ +165 163 | {} + +UP032_0.py:164:1: UP032 [*] Use f-string instead of `format` call | 162 | ) 163 | @@ -977,7 +989,28 @@ UP032_0.py:164:1: UP032 Use f-string instead of `format` call | = help: Convert to f-string -UP032_0.py:174:84: UP032 Use f-string instead of `format` call +ℹ Safe fix +161 161 | 11111111111111111111111111111111111111111111111111111111111111111111111111, +162 162 | ) +163 163 | + 164 |+f""" + 165 |+{1} + 166 |+{2} + 167 |+{111111111111111111111111111111111111111111111111111111111111111111111111111111111111111} +164 168 | """ +165 |-{} +166 |-{} +167 |-{} +168 |-""".format( +169 |-1, +170 |-2, +171 |-111111111111111111111111111111111111111111111111111111111111111111111111111111111111111, +172 |-) +173 169 | +174 170 | aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa = """{} +175 171 | """.format( + +UP032_0.py:174:84: UP032 [*] Use f-string instead of `format` call | 172 | ) 173 | @@ -992,6 +1025,20 @@ UP032_0.py:174:84: UP032 Use f-string instead of `format` call | = help: Convert to f-string +ℹ Safe fix +171 171 | 111111111111111111111111111111111111111111111111111111111111111111111111111111111111111, +172 172 | ) +173 173 | +174 |-aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa = """{} +175 |-""".format( +176 |- 111111 +177 |-) + 174 |+aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa = f"""{111111} + 175 |+""" +178 176 | +179 177 | "{}".format( +180 178 | [ + UP032_0.py:202:1: UP032 Use f-string instead of `format` call | 200 | "{}".format(**c)