-
-
Notifications
You must be signed in to change notification settings - Fork 33.2k
gh-130117: Document why nested Union
, Literal
, and Annotated
types referenced through a type alias are not flattened
#130119
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
Conversation
Most changes to Python require a NEWS entry. Add one using the blurb_it web app or the blurb command-line tool. If this change has little impact on Python users, wait for a maintainer to apply the |
Annotated
types referenced through a type alias are not flattenedUnion
, Literal
, and Annotated
types referenced through a type alias are not flattened
This also applies to |
929121a
to
1aafc37
Compare
Lib/typing.py
Outdated
assert Union[Union[int, str], float] == Union[int, str, float] | ||
However, this does not apply to unions referenced through a type |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think that we should document this in one place, no need to duplicate this info.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you mean the existing duplication between typing.rst
and typing.py
? I assume it's intended so I don't want to make the two diverge by only updating one of them.
Or is it that you'd prefer a separate section for mentioning that Union
/Literal
/Annotated
flattening doesn't work with TypeAliasType
, instead of it being inlined within each type's respective documentation?
I'd rather document a specific caveat about a feature as close as possible to where the feature itself is documented, otherwise it could easily be missed by readers. And since the flattening behavior is explained in each type's respective documentation, it makes sense to follow suit. I'm guessing that this is the intent of the original authors as the overall redundancy in the properties listed for Union
/Literal
/Annotated
probably reduces the need to jump up and down the page to a hypothetical common section about "union-like" types when reading.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In general, the docstrings are meant to be more concise. I think the new information in this PR is specialized enough that we can document it only in typing.rst and not the docstrings.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alright I'll only modify typing.rst
Doc/library/typing.rst
Outdated
is allowed as type argument to ``Literal[...]``, but type checkers may | ||
impose restrictions. See :pep:`586` for more details about literal types. | ||
|
||
``Literal`` is very similar to :class:`Union`, the main difference is that its |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This sentence is likely to cause confusion for many readers. Literal and Union are very different things in the type system.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would it be better as "The Literal annotation supports the same operations as Union"?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's better not to draw comparisons. Literal and Union have similar runtime behavior but they mean different things, and I don't think it will help most readers to compare them.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fair enough
Lib/typing.py
Outdated
assert Union[Union[int, str], float] == Union[int, str, float] | ||
However, this does not apply to unions referenced through a type |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In general, the docstrings are meant to be more concise. I think the new information in this PR is specialized enough that we can document it only in typing.rst and not the docstrings.
Co-authored-by: Jelle Zijlstra <[email protected]>
This has a merge conflict now. |
Thanks @vberlier for the PR, and @JelleZijlstra for merging it 🌮🎉.. I'm working now to backport this PR to: 3.13. |
…ed` types referenced through a type alias are not flattened (pythonGH-130119) (cherry picked from commit b936ccd) Co-authored-by: Valentin Berlier <[email protected]> Co-authored-by: Jelle Zijlstra <[email protected]>
GH-133488 is a backport of this pull request to the 3.13 branch. |
…ted` types referenced through a type alias are not flattened (GH-130119) (#133488) gh-130117: Document why nested `Union`, `Literal`, and `Annotated` types referenced through a type alias are not flattened (GH-130119) (cherry picked from commit b936ccd) Co-authored-by: Valentin Berlier <[email protected]> Co-authored-by: Jelle Zijlstra <[email protected]>
Thanks for taking the time to merge this! Is there an automated workflow that's supposed to close the associated issue or should we close it manually? |
…ed` types referenced through a type alias are not flattened (python#130119) Co-authored-by: Jelle Zijlstra <[email protected]>
typing.Annotated
does not flatten throughtyping.TypeAliasType
#130117📚 Documentation preview 📚: https://cpython-previews--130119.org.readthedocs.build/