-
Notifications
You must be signed in to change notification settings - Fork 116
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
Check callable argument/return types #84
Comments
It's doable but requires nontrivial amount of work. There is a particular issue around type variables where |
This would be extremely valuable for several of our use cases. Does |
Getting the annotations is not a problem. Making a compatibility comparison between them is. |
That makes sense. Would it be reasonable to allow users to opt-in to exact type checking? I.e. "Compatible" could initially be defined as "exactly matches", with enhancements possible in future releases. So, given the signature
Now, all of those cases should succeed eventually, but building a type validator is, as you pointed out, tricky. I think a good path forward would be to start with "overly restrictive but safe and consistent" by requiring people to pass Callables whose annotations explicitly exactly match the receiver's annotation. Then, over time, contributors can gradually improve the meta-type checker to accept more valid input annotations. For example, an easy rule to add would be to check compatibility of annotated types that have zero-argument constructors via With this approach you don't have to make a full general type-compatibility checker all at once, up front. However, it may result in more bug reports due to the artificial restrictiveness of the initial approach. What do you think? |
Some prior art (which works for a surprising number of cases given how little code it is) is here: https://github.com/hyroai/gamla/blob/master/gamla/type_safety.py |
Some more prior art, with a bit better API, but also pretty young/not too widely used: https://github.com/bojiang/typing_utils |
I honestly don't have any bandwidth to work on this at all, but if somebody puts together a PR with accompanying tests, I would be willing to review it. |
No worries, and thanks for all the work you've done on typeguard so far, it's invaluable! I can work on that PR, but due to the initially overly-restrictive checking to be performed it's likely that it'll yield some issue reports of folks who want the type reconciliation to be better (the idea being we could refine it over time). Given that, would you prefer I PR here or do that work in a different library? I don't wanna put it up if it's unlikely to be accepted, and also don't want to cause you more interrupt hassle. |
I don't mind users getting new errors along with the new code, so long as the errors reveal actual type incompatibilities. And as I said, I would accept a PR against this project. |
Thanks. I will work on something but it won't be particularly soon, sorry (working on this on the side of Real Job ™️ ). |
How hard do you think it would be to fully type check a callable? I am not very familiar with all the underlying technology.
The text was updated successfully, but these errors were encountered: