Skip to content

Conversation

@AlexWaygood
Copy link
Member

@AlexWaygoodAlexWaygood commented Jul 24, 2023

Some of this looks a little complicated at first glance, but it's hopefully not too hard to grok

Comment on lines +2651 to +2656
CConverterClassT=TypeVar("CConverterClassT", bound=type["CConverter"])

defadd_c_converter(
f: type[CConverter],
f: CConverterClassT,
name: str|None=None
) ->type[CConverter]:
) ->CConverterClassT:
Copy link
MemberAuthor

@AlexWaygoodAlexWaygoodJul 24, 2023

Choose a reason for hiding this comment

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

By using a TypeVar here (and with the other functions in this PR), we can make the annotation much more expressive.

The annotation currently says "you put in an object f that's some subtype of type[CConverter], and you get out an object that's some subtype of type[CConverter].

The new annotation, by contrast, says, "you put in an object f, and you get out an object that has the same type as whatever the type of f is, as long as the type of f is a subtype of type[CConverter].

Copy link
MemberAuthor

Choose a reason for hiding this comment

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

As an example, with the following snippet:

x=add_c_converter(bool_converter)

Mypy would have inferred the type of x to be type[CConverter] with the current annotation. But with the new annotation, mypy should be able to infer that the type of x is bool_converter.

Copy link
Contributor

Choose a reason for hiding this comment

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

Neat!

Copy link
Contributor

@erlend-aaslanderlend-aasland left a comment

Choose a reason for hiding this comment

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

Thanks!

@AlexWaygoodAlexWaygood merged commit dbfe738 into python:mainJul 25, 2023
@AlexWaygoodAlexWaygood deleted the add-converter-typing branch July 25, 2023 08:18
jtcave pushed a commit to jtcave/cpython that referenced this pull request Jul 27, 2023
Sign up for freeto join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants

@AlexWaygood@erlend-aasland@bedevere-bot