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

Dedicated error code for explicit any #18398

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

hauntsaninja
Copy link
Collaborator

No description provided.

@@ -1241,6 +1241,22 @@ Consider this example:
`PEP 705 <https://peps.python.org/pep-0705>`_ specifies
how ``ReadOnly`` special form works for ``TypedDict`` objects.

.. _code-narrowed-type-not-subtype:

Check that ``TypeIs`` narrows types [narrowed-type-not-subtype]
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this is on by default, so moving it to the correct page while i'm here

Copy link
Contributor

github-actions bot commented Jan 1, 2025

Diff from mypy_primer, showing the effect of this PR on open source code:

trio (https://github.com/python-trio/trio)
+ src/trio/_core/_thread_cache.py:219: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_thread_cache.py:219: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_thread_cache.py:219: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_util.py:24: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_util.py:24: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_util.py:24: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_util.py:181: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_util.py:181: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_util.py:181: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_util.py:189: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_util.py:189: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_util.py:189: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_util.py:253: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_util.py:253: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_util.py:253: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_util.py:350: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_util.py:350: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_util.py:350: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_util.py:353: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_util.py:353: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_util.py:353: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_highlevel_serve_listeners.py:29: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_highlevel_serve_listeners.py:29: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_highlevel_serve_listeners.py:29: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_highlevel_serve_listeners.py:72: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_highlevel_serve_listeners.py:72: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_highlevel_serve_listeners.py:72: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_traps.py:108: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_traps.py:108: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_traps.py:108: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_socket.py:50: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_socket.py:50: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_socket.py:50: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_instrumentation.py:15: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_instrumentation.py:15: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_instrumentation.py:15: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_instrumentation.py:21: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_instrumentation.py:21: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_instrumentation.py:21: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_file_io.py:431: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_file_io.py:431: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_entry_queue.py:20: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_entry_queue.py:20: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_entry_queue.py:20: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_ssl.py:427: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_ssl.py:427: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_ssl.py:427: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_highlevel_open_tcp_stream.py:138: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_highlevel_open_tcp_stream.py:138: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_highlevel_open_tcp_stream.py:138: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1291: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1291: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1291: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1391: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1391: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1391: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1394: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1394: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1394: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1413: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1413: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1413: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1414: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1414: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1414: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1416: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1416: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1416: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1484: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1484: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1484: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1630: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1630: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1630: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1635: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1635: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1635: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1638: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1638: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1638: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1684: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1684: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:1684: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1693: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:1693: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:1693: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:2121: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:2121: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:2121: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_run.py:2423: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_run.py:2423: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_run.py:2423: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:150: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:150: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:150: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_threads.py:151: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_threads.py:151: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:151: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:210: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:210: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:210: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_threads.py:211: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_threads.py:211: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:211: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:255: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:255: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:528: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_threads.py:528: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:528: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_threads.py:573: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_threads.py:573: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_threads.py:573: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_path.py:34: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_path.py:34: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_path.py:34: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_path.py:187: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_path.py:187: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_path.py:197: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/testing/_fake_net.py:511: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/testing/_fake_net.py:511: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/testing/_fake_net.py:511: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_tests/test_subprocess.py:86: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_tests/test_subprocess.py:99: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_tests/test_subprocess.py:119: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_tests/test_subprocess.py:119: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_tests/test_subprocess.py:119: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_tests/test_ssl.py:385: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_tests/test_ssl.py:385: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_tests/test_ssl.py:385: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_tests/test_run.py:1662: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_tests/test_run.py:1662: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_tests/test_run.py:1662: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_tests/test_run.py:1700: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_tests/test_run.py:1700: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_tests/test_run.py:1700: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_tests/test_run.py:1706: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_tests/test_run.py:1706: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_tests/test_run.py:1706: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_core/_tests/test_ki.py:681: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_core/_tests/test_ki.py:681: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_core/_tests/test_ki.py:681: note: Error code "explicit-any" not covered by "type: ignore" comment
+ src/trio/_tests/test_threads.py:59: error: Unused "type: ignore" comment  [unused-ignore]
+ src/trio/_tests/test_threads.py:59: error: Explicit "Any" is not allowed  [explicit-any]
+ src/trio/_tests/test_threads.py:59: note: Error code "explicit-any" not covered by "type: ignore" comment

@A5rocks
Copy link
Contributor

A5rocks commented Jan 1, 2025

I know the diff for trio looks bad, but we're already generally writing out explanations for this so this change is good:

https://github.com/python-trio/trio/blob/7084b564ea6780aa144cdb08fc85bf1cc9e703e0/src/trio/_util.py#L23-L24

-snip, I misread a note as an error-

@hauntsaninja
Copy link
Collaborator Author

Yup, I got here because I realised I could batch some type ignore thrash for trio here: #18397 (comment)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants