Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[ruff] - extend comment deletions for unused-noqa (RUF100) #13105

Merged
merged 2 commits into from
Aug 29, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions crates/ruff_linter/resources/test/fixtures/ruff/RUF100_5.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,13 @@


#import os # noqa: E501

def f():
data = 1
# line below should autofix to `return data # fmt: skip`
return data # noqa: RET504 # fmt: skip

def f():
data = 1
# line below should autofix to `return data`
return data # noqa: RET504 - intentional incorrect noqa, will be removed
34 changes: 17 additions & 17 deletions crates/ruff_linter/src/checkers/noqa.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use rustc_hash::FxHashSet;
use ruff_diagnostics::{Diagnostic, Edit, Fix};
use ruff_python_trivia::CommentRanges;
use ruff_source_file::Locator;
use ruff_text_size::Ranged;
use ruff_text_size::{Ranged, TextRange};

use crate::fix::edits::delete_comment;
use crate::noqa::{
Expand Down Expand Up @@ -118,10 +118,12 @@ pub(crate) fn check_noqa(
match &line.directive {
Directive::All(directive) => {
if line.matches.is_empty() {
let mut diagnostic =
Diagnostic::new(UnusedNOQA { codes: None }, directive.range());
diagnostic
.set_fix(Fix::safe_edit(delete_comment(directive.range(), locator)));
let edit = delete_comment(directive.range(), locator);
let mut diagnostic = Diagnostic::new(
UnusedNOQA { codes: None },
TextRange::new(directive.start(), edit.end()),
);
diagnostic.set_fix(Fix::safe_edit(edit));

diagnostics.push(diagnostic);
}
Expand Down Expand Up @@ -172,6 +174,14 @@ pub(crate) fn check_noqa(
&& unknown_codes.is_empty()
&& unmatched_codes.is_empty())
{
let edit = if valid_codes.is_empty() {
delete_comment(directive.range(), locator)
} else {
Edit::range_replacement(
format!("# noqa: {}", valid_codes.join(", ")),
directive.range(),
)
};
let mut diagnostic = Diagnostic::new(
UnusedNOQA {
codes: Some(UnusedCodes {
Expand All @@ -193,19 +203,9 @@ pub(crate) fn check_noqa(
.collect(),
}),
},
directive.range(),
TextRange::new(directive.start(), edit.end()),
);
if valid_codes.is_empty() {
diagnostic.set_fix(Fix::safe_edit(delete_comment(
directive.range(),
locator,
)));
} else {
diagnostic.set_fix(Fix::safe_edit(Edit::range_replacement(
format!("# noqa: {}", valid_codes.join(", ")),
directive.range(),
)));
}
diagnostic.set_fix(Fix::safe_edit(edit));
diagnostics.push(diagnostic);
}
}
Expand Down
7 changes: 2 additions & 5 deletions crates/ruff_linter/src/fix/edits.rs
Original file line number Diff line number Diff line change
Expand Up @@ -99,11 +99,8 @@ pub(crate) fn delete_comment(range: TextRange, locator: &Locator) -> Edit {
}
// Ex) `x = 1 # noqa here`
else {
// Replace `# noqa here` with `# here`.
Edit::range_replacement(
"# ".to_string(),
TextRange::new(range.start(), range.end() + trailing_space_len),
)
// Remove `# noqa here` and whitespace
Edit::deletion(range.start() - leading_space_len, line_range.end())
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@ source: crates/ruff_linter/src/rules/ruff/mod.rs
---
RUF100_3.py:1:1: RUF100 [*] Unused blanket `noqa` directive
|
1 | # noqa
| ^^^^^^ RUF100
2 | # noqa # comment
3 | print() # noqa
1 | / # noqa
2 | | # noqa # comment
| |_^ RUF100
3 | print() # noqa
4 | print() # noqa # comment
|
= help: Remove unused `noqa` directive

Expand All @@ -20,7 +21,7 @@ RUF100_3.py:2:1: RUF100 [*] Unused blanket `noqa` directive
|
1 | # noqa
2 | # noqa # comment
| ^^^^^^ RUF100
| ^^^^^^^ RUF100
3 | print() # noqa
4 | print() # noqa # comment
|
Expand Down Expand Up @@ -59,7 +60,7 @@ RUF100_3.py:4:10: RUF100 [*] Unused blanket `noqa` directive
2 | # noqa # comment
3 | print() # noqa
4 | print() # noqa # comment
| ^^^^^^ RUF100
| ^^^^^^^ RUF100
5 | print() # noqa # comment
6 | print() # noqa comment
|
Expand All @@ -80,7 +81,7 @@ RUF100_3.py:5:10: RUF100 [*] Unused blanket `noqa` directive
3 | print() # noqa
4 | print() # noqa # comment
5 | print() # noqa # comment
| ^^^^^^ RUF100
| ^^^^^^^^ RUF100
6 | print() # noqa comment
7 | print() # noqa comment
|
Expand All @@ -101,7 +102,7 @@ RUF100_3.py:6:10: RUF100 [*] Unused blanket `noqa` directive
4 | print() # noqa # comment
5 | print() # noqa # comment
6 | print() # noqa comment
| ^^^^^^ RUF100
| ^^^^^^^^^^^^^^ RUF100
7 | print() # noqa comment
8 | print(a) # noqa
|
Expand All @@ -112,7 +113,7 @@ RUF100_3.py:6:10: RUF100 [*] Unused blanket `noqa` directive
4 4 | print() # noqa # comment
5 5 | print() # noqa # comment
6 |-print() # noqa comment
6 |+print() # comment
6 |+print()
7 7 | print() # noqa comment
8 8 | print(a) # noqa
9 9 | print(a) # noqa # comment
Expand All @@ -122,7 +123,7 @@ RUF100_3.py:7:10: RUF100 [*] Unused blanket `noqa` directive
5 | print() # noqa # comment
6 | print() # noqa comment
7 | print() # noqa comment
| ^^^^^^ RUF100
| ^^^^^^^^^^^^^^^ RUF100
8 | print(a) # noqa
9 | print(a) # noqa # comment
|
Expand All @@ -133,19 +134,20 @@ RUF100_3.py:7:10: RUF100 [*] Unused blanket `noqa` directive
5 5 | print() # noqa # comment
6 6 | print() # noqa comment
7 |-print() # noqa comment
7 |+print() # comment
7 |+print()
8 8 | print(a) # noqa
9 9 | print(a) # noqa # comment
10 10 | print(a) # noqa # comment

RUF100_3.py:14:1: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
|
12 | print(a) # noqa comment
13 |
14 | # noqa: E501, F821
| ^^^^^^^^^^^^^^^^^^ RUF100
15 | # noqa: E501, F821 # comment
16 | print() # noqa: E501, F821
12 | print(a) # noqa comment
13 |
14 | / # noqa: E501, F821
15 | | # noqa: E501, F821 # comment
| |_^ RUF100
dhruvmanila marked this conversation as resolved.
Show resolved Hide resolved
16 | print() # noqa: E501, F821
17 | print() # noqa: E501, F821 # comment
|
= help: Remove unused `noqa` directive

Expand All @@ -162,7 +164,7 @@ RUF100_3.py:15:1: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
|
14 | # noqa: E501, F821
15 | # noqa: E501, F821 # comment
| ^^^^^^^^^^^^^^^^^^ RUF100
| ^^^^^^^^^^^^^^^^^^^ RUF100
16 | print() # noqa: E501, F821
17 | print() # noqa: E501, F821 # comment
|
Expand Down Expand Up @@ -204,7 +206,7 @@ RUF100_3.py:17:10: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
15 | # noqa: E501, F821 # comment
16 | print() # noqa: E501, F821
17 | print() # noqa: E501, F821 # comment
| ^^^^^^^^^^^^^^^^^^ RUF100
| ^^^^^^^^^^^^^^^^^^^ RUF100
18 | print() # noqa: E501, F821 # comment
19 | print() # noqa: E501, F821 comment
|
Expand All @@ -225,7 +227,7 @@ RUF100_3.py:18:10: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
16 | print() # noqa: E501, F821
17 | print() # noqa: E501, F821 # comment
18 | print() # noqa: E501, F821 # comment
| ^^^^^^^^^^^^^^^^^^ RUF100
| ^^^^^^^^^^^^^^^^^^^^ RUF100
19 | print() # noqa: E501, F821 comment
20 | print() # noqa: E501, F821 comment
|
Expand All @@ -246,7 +248,7 @@ RUF100_3.py:19:10: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
17 | print() # noqa: E501, F821 # comment
18 | print() # noqa: E501, F821 # comment
19 | print() # noqa: E501, F821 comment
| ^^^^^^^^^^^^^^^^^^ RUF100
| ^^^^^^^^^^^^^^^^^^^^^^^^^^ RUF100
20 | print() # noqa: E501, F821 comment
21 | print(a) # noqa: E501, F821
|
Expand All @@ -257,7 +259,7 @@ RUF100_3.py:19:10: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
17 17 | print() # noqa: E501, F821 # comment
18 18 | print() # noqa: E501, F821 # comment
19 |-print() # noqa: E501, F821 comment
19 |+print() # comment
19 |+print()
20 20 | print() # noqa: E501, F821 comment
21 21 | print(a) # noqa: E501, F821
22 22 | print(a) # noqa: E501, F821 # comment
Expand All @@ -267,7 +269,7 @@ RUF100_3.py:20:10: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
18 | print() # noqa: E501, F821 # comment
19 | print() # noqa: E501, F821 comment
20 | print() # noqa: E501, F821 comment
| ^^^^^^^^^^^^^^^^^^ RUF100
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^ RUF100
21 | print(a) # noqa: E501, F821
22 | print(a) # noqa: E501, F821 # comment
|
Expand All @@ -278,7 +280,7 @@ RUF100_3.py:20:10: RUF100 [*] Unused `noqa` directive (unused: `E501`, `F821`)
18 18 | print() # noqa: E501, F821 # comment
19 19 | print() # noqa: E501, F821 comment
20 |-print() # noqa: E501, F821 comment
20 |+print() # comment
20 |+print()
21 21 | print(a) # noqa: E501, F821
22 22 | print(a) # noqa: E501, F821 # comment
23 23 | print(a) # noqa: E501, F821 # comment
Expand Down Expand Up @@ -428,5 +430,3 @@ RUF100_3.py:28:39: RUF100 [*] Unused `noqa` directive (unused: `E501`)
27 27 | print(a) # comment with unicode µ # noqa: E501
28 |-print(a) # comment with unicode µ # noqa: E501, F821
28 |+print(a) # comment with unicode µ # noqa: F821


Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ RUF100_5.py:11:1: ERA001 Found commented-out code
|
11 | #import os # noqa: E501
| ^^^^^^^^^^^^^^^^^^^^^^^^ ERA001
12 |
13 | def f():
|
= help: Remove commented-out code

Expand All @@ -32,11 +34,16 @@ RUF100_5.py:11:1: ERA001 Found commented-out code
9 9 |
10 10 |
11 |-#import os # noqa: E501
12 11 |
13 12 | def f():
14 13 | data = 1

RUF100_5.py:11:13: RUF100 [*] Unused `noqa` directive (unused: `E501`)
|
11 | #import os # noqa: E501
| ^^^^^^^^^^^^ RUF100
12 |
13 | def f():
|
= help: Remove unused `noqa` directive

Expand All @@ -46,5 +53,43 @@ RUF100_5.py:11:13: RUF100 [*] Unused `noqa` directive (unused: `E501`)
10 10 |
11 |-#import os # noqa: E501
11 |+#import os
12 12 |
13 13 | def f():
14 14 | data = 1

RUF100_5.py:16:18: RUF100 [*] Unused `noqa` directive (non-enabled: `RET504`)
|
14 | data = 1
15 | # line below should autofix to `return data # fmt: skip`
16 | return data # noqa: RET504 # fmt: skip
| ^^^^^^^^^^^^^^^ RUF100
17 |
18 | def f():
|
= help: Remove unused `noqa` directive

ℹ Safe fix
13 13 | def f():
14 14 | data = 1
15 15 | # line below should autofix to `return data # fmt: skip`
16 |- return data # noqa: RET504 # fmt: skip
16 |+ return data # fmt: skip
17 17 |
18 18 | def f():
19 19 | data = 1

RUF100_5.py:21:18: RUF100 [*] Unused `noqa` directive (non-enabled: `RET504`)
|
19 | data = 1
20 | # line below should autofix to `return data`
21 | return data # noqa: RET504 - intentional incorrect noqa, will be removed
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ RUF100
|
= help: Remove unused `noqa` directive

ℹ Safe fix
18 18 | def f():
19 19 | data = 1
20 20 | # line below should autofix to `return data`
21 |- return data # noqa: RET504 - intentional incorrect noqa, will be removed
21 |+ return data
Loading