-
Notifications
You must be signed in to change notification settings - Fork 1
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
Type checking with pyright #164
Conversation
After sitting with this, I think my preference would be to remove |
I agree with opting for non-strict mode, as this doesn't appear to be a complex application. Removing strict could make the codebase cleaner and enable faster development while still let us to selectively apply strict checks where needed. |
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 visually inspected the changes for type checking, everything looks good to me.
The types are good and improve the readability for sure. Maybe more discussion about the strict mode to the team? Also, it seems like a bunch of warning happened because the Reactive.Value[] type was not equal to primitive type even though they are both int/float/other.
Let me merge main into this and we can go from there.
These reactive.values do need to be treated differently from the types they wrap, and having a warning about these is actually one of the big wins. To get the wrapped value from a reactive.value, you need to call it as a function:
(This is not an actual repl session: Reactive values don't work outside of a reactive context, so this wouldn't work.) |
Tidied up after merge from main, and applied typing with the nice NamedTuples that were introduced in the refactoring of code generation. Merging this much will be a big improvement, and we can still make incremental improvements. |
pyproject.toml
strict
mode, and ignore the templates inno-test
# type: ignore
type: ignore
, we could dropstrict
, but I think the reminders are good.weights
are different from others, because the user is selecting a string, which we need to then explicitly cast to a number. Typing makes this more explicit..finish()
, rather thanstr()
; The old way would require me to implement a more complicated interface to really comply with the typing.My plan is to continue this work incrementally, but I think having the checks in place is enough for now. I would particularly like to clean up a couple places where
dicts
could be replaced withNamedTuples
.For the reviewer:
type: ignore
that you think could use more attention?