KEMBAR78
Reject promotions when checking against protocols. by tyralla · Pull Request #18360 · python/mypy · GitHub
Skip to content

Conversation

@tyralla
Copy link
Collaborator

@tyralla tyralla commented Dec 29, 2024

Fixes #18359
Fixes #18257
Linking #18343

The change is simple but may be way too general. Making it more precise should be straightforward, but I want to see the Mypy Primer results and hear other opinions first.

@github-actions
Copy link
Contributor

According to mypy_primer, this change doesn't affect type check results on a corpus of open source code. ✅

Copy link
Collaborator

@hauntsaninja hauntsaninja left a comment

Choose a reason for hiding this comment

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

This looks good to me, promotions should be entirely about nominal typing

(Generally speaking, I think float.hex is a small wart that we should not contort too hard to get type safety for. See also python/cpython#100268 (comment))

@hauntsaninja hauntsaninja merged commit ac6151a into python:master Dec 29, 2024
18 checks passed
@tyralla tyralla deleted the reject_promotions_when_checking_against_protocols branch January 4, 2025 22:41
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.

false negative: int and bool don't implement .hex() float and complex forcibly change invariant types to covariant

2 participants