Pyright can check exhaustiveness of match statements on unions
from mao@lemmy.sdf.org to python@programming.dev on 23 Apr 2024 12:39
https://lemmy.sdf.org/post/15730775
from mao@lemmy.sdf.org to python@programming.dev on 23 Apr 2024 12:39
https://lemmy.sdf.org/post/15730775
Twitter user @DanyX23:
TIL: pyright, the python type checking engine that is used by VS Code, has support for exhaustiveness checking for match statements with union types!
If you add the following to your pyproject.toml, you’ll get the attached warning
[tool.pyright] reportMatchNotExhaustive = true
#python
threaded - newest
Yes it does, yes it’s brilliant!
This is honestly so frustrating to see bc I’ll still never understand why Python isn’t just statically typed.
It’s right there in the Zen:
It wouldn’t even have to be less simple as it could still be weakly typed, a la Rust or Haskell, but not as robust.
You wouldn’t need these extra special tools if the language was just built right!
Same goes for the try/catch exception system where runtime errors can pop up bc you don’t have to handle exceptions:
Python is a good language that could’ve been a great one smh
I feel like Python is coming to its senses in the recent years, with releases focusing on typing constructs and the match statement. I think they’re on the path to be a great statically typed language, don’t you think?
I see three possible ways to go about errors:
The criticism I have to Python exceptions is that there should be a way to explicitly see the exceptions a function raises, maybe as part of the function signature like in Java.
To put it another way, I don’t think errors as returned values are immediately better than exceptions. I like the way Rust handles them for instance, but an unsuccessful .unwrap() is not that different from an unhandled exception. I just wish the possible exceptions raised were explicitly stated.
I mean thats one of the big points of python and why you wanna use it in the first place.
I personally don’t main python but to me this all seems like a effort to retrofit the language for use in large enterprise and web applications, something for which it honestly never should have been used this heavily in the first place. I guess the state of the world 10 years ago let to it, with .NET not officially being multiplat, Java being Java and Rust, Kotlin and Go being in their infancy.
To me Python always was a cool language to write small scripts to automate certain things. Something a single developer writes with < 10K LoC. Where than you can achieve the same thing with way less code and less hastle like setting up a seperate build tool
If your gonna go heavy on typing and error handling but don’t want the complexity of a compiled language just use a .NET or JVM lang, honestly. They are fundamentally built around strong typing and use that information for much better performance and developer experience.
Or if you just want THE most flexible typesystem where you can specify types as broad or specific as possible typescript takes the cake.
I write Python and Typescript with full typing for my day job, and it’s pretty nice. Here’s the general workflow:
In development I get the benefit of most of the types being specified, but I don’t need to specify everything until I’m done. I much prefer Python to Typescript, but my hands are tied on the FE.
If I needed better performance though, I’d write in Rust, which is actually what I use for most of my hobby projects.
There are various ways to monitor and handle types, they just aren’t set up right out of the box. It’s not uncommon for a language to be greatly enhanced by libraries/extensions. Having a robust development environment and standards are just part of writing good code.
This is not an apology for python not having it all out of the box, I think it should. Some things.just take setup and for now thats how it is.
Can eli5 this for me?
Python lets you add static type annotations to your program, so you can say “this variable should be and int or a string”, and that means Pyright (a fantastic static type checker) can tell you if you screw up and forget that it might be a string.
It also does exhaustiveness checking for enums! Pyright is probably the best thing about Python.
twitter.com/DanyX23/status/1778045930291319268?t=…