Do not push partial types to the binder#20202
Merged
JukkaL merged 2 commits intopython:masterfrom Nov 18, 2025
Merged
Conversation
Contributor
|
According to mypy_primer, this change doesn't affect type check results on a corpus of open source code. ✅ |
ilevkivskyi
approved these changes
Nov 8, 2025
Member
ilevkivskyi
left a comment
There was a problem hiding this comment.
I think this is correct, but I will give Jukka a chance to look at this as well.
JukkaL
reviewed
Nov 10, 2025
| if int(): | ||
| self.x = None | ||
| return | ||
| self.x = [""] |
Collaborator
There was a problem hiding this comment.
Also add a variant test case where the second assignment assigns a partial type as well -- e.g. self.x = [] followed by self.x.append('x').
Collaborator
There was a problem hiding this comment.
I tried this out, and it appears that the variant I proposed fails to infer the correct type even without using --allow-redefinition-new, so it's a pre-existing issue. I'll create an issue about it.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Fixes #19996.
This was unearthed by #19400 where
is_subtype(Partial<X>, Partial<X>)started returning True - before thatbinder.assign_type(expr, Partial<None>, Partial<None>)just returned early. If I understand correctly, that is how Partial should be handled here: we do not want to push partials to the binder. I do not think we should add a special case for that (both False and True make some sense for a partial type, I am not convinced that either one is marginally better), so I just add an explicit guard to skip adding partial types here.