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

Enable PYI033 for .py files #4166

Closed

Conversation

JonathanPlasse
Copy link
Contributor

It is implemented as PYI033.

Hm, looks like this is only for stub files (.pyi) I cannot get it work for normal python files. man_shrugging

@github-actions
Copy link
Contributor

github-actions bot commented Apr 30, 2023

PR Check Results

Ecosystem

✅ ecosystem check detected no changes.

Benchmark

Linux

group                                      main                                   pr
-----                                      ----                                   --
linter/all-rules/large/dataset.py          1.00     14.0±0.06ms     2.9 MB/sec    1.00     14.0±0.07ms     2.9 MB/sec
linter/all-rules/numpy/ctypeslib.py        1.00      3.4±0.01ms     4.9 MB/sec    1.01      3.4±0.01ms     4.9 MB/sec
linter/all-rules/numpy/globals.py          1.00    422.2±0.89µs     7.0 MB/sec    1.00    422.3±0.75µs     7.0 MB/sec
linter/all-rules/pydantic/types.py         1.00      5.8±0.01ms     4.4 MB/sec    1.00      5.8±0.01ms     4.4 MB/sec
linter/default-rules/large/dataset.py      1.00      6.7±0.01ms     6.0 MB/sec    1.00      6.8±0.01ms     6.0 MB/sec
linter/default-rules/numpy/ctypeslib.py    1.00   1456.9±4.51µs    11.4 MB/sec    1.00   1460.4±2.37µs    11.4 MB/sec
linter/default-rules/numpy/globals.py      1.00    164.2±0.53µs    18.0 MB/sec    1.01    165.4±2.77µs    17.8 MB/sec
linter/default-rules/pydantic/types.py     1.00      3.0±0.01ms     8.4 MB/sec    1.00      3.0±0.01ms     8.4 MB/sec
parser/large/dataset.py                    1.00      5.4±0.01ms     7.6 MB/sec    1.00      5.3±0.00ms     7.6 MB/sec
parser/numpy/ctypeslib.py                  1.01   1061.5±0.60µs    15.7 MB/sec    1.00   1051.9±2.31µs    15.8 MB/sec
parser/numpy/globals.py                    1.00    108.7±0.14µs    27.1 MB/sec    1.00    108.2±0.44µs    27.3 MB/sec
parser/pydantic/types.py                   1.00      2.3±0.00ms    11.1 MB/sec    1.00      2.3±0.00ms    11.1 MB/sec

Windows

group                                      main                                   pr
-----                                      ----                                   --
linter/all-rules/large/dataset.py          1.06     26.7±0.63ms  1559.7 KB/sec    1.00     25.3±0.65ms  1647.2 KB/sec
linter/all-rules/numpy/ctypeslib.py        1.06      6.6±0.35ms     2.5 MB/sec    1.00      6.2±0.25ms     2.7 MB/sec
linter/all-rules/numpy/globals.py          1.00   708.4±39.50µs     4.2 MB/sec    1.01   717.2±47.48µs     4.1 MB/sec
linter/all-rules/pydantic/types.py         1.01     10.7±0.43ms     2.4 MB/sec    1.00     10.5±0.42ms     2.4 MB/sec
linter/default-rules/large/dataset.py      1.00     12.2±0.49ms     3.3 MB/sec    1.01     12.3±0.38ms     3.3 MB/sec
linter/default-rules/numpy/ctypeslib.py    1.00      2.5±0.08ms     6.8 MB/sec    1.04      2.5±0.12ms     6.5 MB/sec
linter/default-rules/numpy/globals.py      1.00   301.3±29.78µs     9.8 MB/sec    1.01   303.1±23.68µs     9.7 MB/sec
linter/default-rules/pydantic/types.py     1.00      5.4±0.18ms     4.7 MB/sec    1.02      5.5±0.33ms     4.6 MB/sec
parser/large/dataset.py                    1.16     11.3±0.50ms     3.6 MB/sec    1.00      9.7±0.31ms     4.2 MB/sec
parser/numpy/ctypeslib.py                  1.16      2.1±0.10ms     8.0 MB/sec    1.00  1804.8±45.80µs     9.2 MB/sec
parser/numpy/globals.py                    1.09   209.1±11.28µs    14.1 MB/sec    1.00    191.5±7.86µs    15.4 MB/sec
parser/pydantic/types.py                   1.15      4.7±0.36ms     5.5 MB/sec    1.00      4.0±0.14ms     6.3 MB/sec

@charliermarsh
Copy link
Member

I'd been hesitant to enable these rules for .py files since it's a deviation from flake8-pyi. I know there's value in enabling this, and a few others which aren't .pyi-file specific. I wonder if it should be opt-in, since it's a deviation from upstream... What do you think? (I'd be curious if there's documented reasoning for flake8-pyi on limiting to .pyi files, I bet there is but I'm on airplane Wi-Fi.)

@JonathanPlasse
Copy link
Contributor Author

No flake8-pyi rules are activated on .py files.
I think there is an issue on which rules could be enable on .py files.

@JonathanPlasse
Copy link
Contributor Author

JonathanPlasse commented May 1, 2023

Here is the list.
qutebrowser/qutebrowser#7098 (comment)

@AlexWaygood
Copy link
Member

Here is the list. qutebrowser/qutebrowser#7098 (comment)

We've discussed several times at flake8-pyi whether we wanted to support running our checks on .py files, as a lot of our checks could indeed apply to .py files as well as .pyi files. (The list I gave in qutebrowser/qutebrowser#7098 (comment) is now incomplete, since I wrote that more than a year ago, and we've added lots of checks since!)

The main reason we don't want to support .py files at flake8-pyi it is that it would complicate the code base in an annoying way. We'd have to do loads of if file.suffix == ".pyi" checks everywhere, and it would be a pain. We're also a little wary of scope creep.

I'm not too familiar with ruff's codebase (and don't know rust 😆), but my impression is that neither of these concerns apply to ruff in the same way. (You obviously have a... much broader scope than flake8-pyi :)

If I were writing flake8-pyi from scratch today, I'd probably separate it into two plugins -- one which specialised in type hints (and could be run on .py files and .pyi files), and one which specialised in checks that only applied to .pyi files. But I'm not writing it from scratch; I'm pretty happy with how it works overall; and separating it into two plugins at this stage sounds like a lot of work that I don't really feel like doing right now 😆

@JonathanPlasse JonathanPlasse force-pushed the enable-pyi033-for-py-files branch from 831ceb8 to 787a2f8 Compare May 3, 2023 17:47
@charliermarsh charliermarsh added the rule Implementing or modifying a lint rule label May 12, 2023
@JonathanPlasse JonathanPlasse force-pushed the enable-pyi033-for-py-files branch from 787a2f8 to 422e8d0 Compare May 14, 2023 15:09
@JonathanPlasse
Copy link
Contributor Author

Should we go ahead and merge this or do we want to activate all rules that can apply to .py files in this PR?

@nm-remarkable
Copy link
Contributor

Should we go ahead and merge this or do we want to activate all rules that can apply to .py files in this PR?

IMO a Issue tracking all the rules that should be enabled in .py files from this plugin would be nice.

Then each PR takes it as one rule at a time, which can then be crossed of from the Issue when merged.

@calumy calumy mentioned this pull request May 17, 2023
@JonathanPlasse JonathanPlasse force-pushed the enable-pyi033-for-py-files branch from 422e8d0 to b4478c6 Compare May 18, 2023 16:44
@JonathanPlasse
Copy link
Contributor Author

What is blocking this PR?

@charliermarsh
Copy link
Member

I think there are two things:

  1. I'd like to turn on a bunch of the flake8-pyi rules at once, rather than having inconsistency within the rule set.
  2. There are reasons to use type comments in .py files (see, e.g., False positive with F401 (imported but unused) for type comments #1619 (comment)) that don't apply to .pyi files, which I don't quite know how to resolve.

@JonathanPlasse
Copy link
Contributor Author

Is it possible to get the corresponding statement or expression from a TextSize?

@MichaReiser
Copy link
Member

Is it possible to get the corresponding statement or expression from a TextSize?

We could do a binary search over the tree (at least after my changes to RustPython merge that include the decorators in the function range) but I would discourage from doing it in general. What are you trying to do?

@JonathanPlasse
Copy link
Contributor Author

JonathanPlasse commented May 22, 2023

@charliermarsh
Copy link
Member

Closing for now, as I want to do this in a consolidated pass for all rules.

@JonathanPlasse JonathanPlasse deleted the enable-pyi033-for-py-files branch October 17, 2023 11:07
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
rule Implementing or modifying a lint rule
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants