this post was submitted on 25 Sep 2024
893 points (97.3% liked)
Programming
17119 readers
114 users here now
Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!
Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.
Hope you enjoy the instance!
Rules
Rules
- Follow the programming.dev instance rules
- Keep content related to programming in some way
- If you're posting long videos try to add in some form of tldr for those who don't want to watch videos
Wormhole
Follow the wormhole through a path of communities [email protected]
founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
Python doesn't check the types of function headers though. They're only hints for the programmer.
OP suggested that linters for python won't catch attribute errors, which they 100% will if you use type hints, as you should.
What happens at runtime is really relevant in this case.
Linters 100% won't. A static type checker is not a linter.
I don't want to get into an Internet argument over pedantry. Linter is often used as a catch-all term for static analysis tools.
Wikipedia defines it as
Catching type errors and attribute errors would fit under this description, if you use a different, more precise definition at your workplace, cool, then we just have different definitions for it. The point is that your IDE should automatically detect the errors regardless of what you call it.
In common usage a linter detects code that is legal but likely a mistake, or code that doesn't follow best practice.
Although static type checkers do fit in that definition, that definition is overly broad and they would not be called a "linter".
Here is how static type checkers describe themselves:
Here is how linters describe themselves:
(Ok I guess it's a bit redundant for Pylint to say it is a linter.)
You get the idea... Linters are heuristic and advisory. Quite different to static type checking.