-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
[refurb
] Implement write-whole-file
(FURB103
)
#10802
Conversation
774638f
to
d0cd4ae
Compare
51 | # writes a single time to file and that bit they can replace. | ||
| | ||
|
||
FURB103.py:58:6: FURB103 `open` and `write` should be replaced by `Path("file.txt").write_text(newline="\r\n", foobar)` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I understand that foobar
is being placed after newline="\r\n"
because the generator uses source order, and foobar
comes later, but I'm not sure how to remedy it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, that's unfortunate. I think I'd suggest to have two different variants of make_suggestion
. We can keep the one in read_whole_file
as is.
Here, one thing to note is that the write
function only takes in one positional argument which we can assume. So, the make_suggestion
in write_whole_file
would take in the argument expression as an additional parameter.
We can use relocate_expr
to relocate it to the default range before calling the make_suggestion
function.
pub(super) fn make_suggestion(
open: &FileOpen<'_>,
arg: &Expr,
generator: Generator,
) -> SourceCodeSnippet {
let name = ast::ExprName {
id: open.mode.pathlib_method(),
ctx: ast::ExprContext::Load,
range: TextRange::default(),
};
let call = ast::ExprCall {
func: Box::new(name.into()),
arguments: ast::Arguments {
args: Box::new([arg.clone()]),
keywords: open.keywords.iter().copied().cloned().collect(),
range: TextRange::default(),
},
range: TextRange::default(),
};
SourceCodeSnippet::from_str(&generator.expr(&call.into()))
}
|
code | total | + violation | - violation | + fix | - fix |
---|---|---|---|---|---|
FURB103 | 137 | 137 | 0 | 0 | 0 |
Formatter (stable)
✅ ecosystem check detected no format changes.
Formatter (preview)
✅ ecosystem check detected no format changes.
21 | f.write(b"abc") | ||
| | ||
|
||
FURB103.py:24:6: FURB103 `open` and `write` should be replaced by `Path("file.txt").write_text(encoding="utf8", foobar)` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think encoding="utf8"
keyword argument should go after foobar
positional argument
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ya it's the same thing I commented above, but I'm not sure how to correct it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks you for the PR.
I think a lot of the definitions and functions are repeated as you've mentioned. It would be useful to move the common structs and functions to crates/ruff_linter/src/rules/refurb/helpers.rs
module to avoid having duplicate logic. You can find similar examples in other rule modules as well. Can you please make this change?
71accbc
to
2d35452
Compare
@dhruvmanila Done. Any suggestion on the comments above? |
2d35452
to
bc059af
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for quickly following up with the requested change.
I've a few suggestion to avoid cloning and have provided a suggestion for the incorrect argument order that you've highlighted.
I haven't looked at the test cases yet which I'll do so now.
51 | # writes a single time to file and that bit they can replace. | ||
| | ||
|
||
FURB103.py:58:6: FURB103 `open` and `write` should be replaced by `Path("file.txt").write_text(newline="\r\n", foobar)` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, that's unfortunate. I think I'd suggest to have two different variants of make_suggestion
. We can keep the one in read_whole_file
as is.
Here, one thing to note is that the write
function only takes in one positional argument which we can assume. So, the make_suggestion
in write_whole_file
would take in the argument expression as an additional parameter.
We can use relocate_expr
to relocate it to the default range before calling the make_suggestion
function.
pub(super) fn make_suggestion(
open: &FileOpen<'_>,
arg: &Expr,
generator: Generator,
) -> SourceCodeSnippet {
let name = ast::ExprName {
id: open.mode.pathlib_method(),
ctx: ast::ExprContext::Load,
range: TextRange::default(),
};
let call = ast::ExprCall {
func: Box::new(name.into()),
arguments: ast::Arguments {
args: Box::new([arg.clone()]),
keywords: open.keywords.iter().copied().cloned().collect(),
range: TextRange::default(),
},
range: TextRange::default(),
};
SourceCodeSnippet::from_str(&generator.expr(&call.into()))
}
@augustelalande Sorry, I was playing around with the suggestions I made which fixes the "suggestion" problem, so I've pushed that. I'll list down what all changes I made, feel free to revert any of them if you think otherwise:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for working on this!
(Looking at the ecosystem checks, making sure they're correct.) |
Thanks for cleaning things up. |
## Summary Implement `write-whole-file` (`FURB103`), part of astral-sh#1348. This is largely a copy and paste of `read-whole-file` astral-sh#7682. ## Test Plan Text fixture added. --------- Co-authored-by: Dhruv Manilawala <[email protected]>
Summary
Implement
write-whole-file
(FURB103
), part of #1348. This is largely a copy and paste ofread-whole-file
#7682.Test Plan
Text fixture added.