KEMBAR78
Experiment: decouple types.DynamicClassAttribute from property by tungol · Pull Request #12762 · python/typeshed · GitHub
Skip to content

Conversation

@tungol
Copy link
Contributor

@tungol tungol commented Oct 9, 2024

I'm curious to see what the tests look like.

I'm curious to see what the tests look like.
@tungol tungol marked this pull request as draft October 9, 2024 23:41
@github-actions

This comment has been minimized.

@tungol
Copy link
Contributor Author

tungol commented Oct 10, 2024

Less breakage than I imagined. "Run mypy against the stubs" passes for 3.11+, which I suspect means that enum.property being named property is sufficient to get (some of) the special treatment, but the primer results show it's not all of it. One other thing I want to try.

@github-actions
Copy link
Contributor

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

ignite (https://github.com/pytorch/ignite)
+ ignite/engine/events.py:206: error: Definition of "name" in base class "CallableEventWithFilter" is incompatible with definition in base class "Enum"  [misc]

nox (https://github.com/wntrblm/nox)
+ nox/sessions.py:1106: error: Returning Any from function declared to return "str"  [no-any-return]

@tungol
Copy link
Contributor Author

tungol commented Oct 10, 2024

Subclassing doesn't appear to make any difference.

@tungol tungol closed this Oct 10, 2024
@AlexWaygood
Copy link
Member

"Run mypy against the stubs" passes for 3.11+, which I suspect means that enum.property being named property is sufficient to get (some of) the special treatment,

It's actually because mypy hardcodes in some extra special casing to cope with typeshed's stubs here. See python/mypy#14133

@tungol tungol deleted the DynamicClassAttribute branch October 10, 2024 08:20
@tungol
Copy link
Contributor Author

tungol commented Oct 10, 2024

Thanks for the context, I appreciate it

JukkaL pushed a commit to python/mypy that referenced this pull request Nov 21, 2024
This enables typeshed to define types.DynamicClassAttribute as a
different class from builtins.property without breakage.

Would enable python/typeshed#12762
see also #14133
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