gh-89547: Add support for nesting special forms like Final #116092
Closed
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.
Resolves this issue. The main goal was to permit
ClassVar[Final[int]]
andFinal[ClassVar[int]]
. This drops validation check that Final/ClassVar argument is not a special form.This does allow some silly cases like
ClassVar[ClassVar[int]]
but I think it's simpler to allow them then have more complex validation rules at runtime. I did not remove special form check for other forms soUnion[ClassVar[int], int]
remains forbidden andlist[ClassVar[int]]
is also forbidden. There already was a test case thatlist[ClassVar[int]]
fails.I also added couple tests for Annotated to ensure it can nest freely with
ClassVar
/Final
.