Skip to content
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

Add type hints to the labscript API #105

Open
dihm opened this issue Jan 28, 2024 · 0 comments
Open

Add type hints to the labscript API #105

dihm opened this issue Jan 28, 2024 · 0 comments
Labels
enhancement New feature or request major

Comments

@dihm
Copy link
Contributor

dihm commented Jan 28, 2024

Given the state of auto-completion in modern editors, it would be a fairly significant quality of life improvement to add type hints to the API-like portions of the suite, labscript being the obvious primary candidate for usefulness (but not ease).

A few things would need to be decided as far as strategy.

  • Enforcement: adding type hints without confirming them is just asking for trouble. We'd need to decide a checker (mypy or pydantic, etc) as well as deciding if we would want to automate those checks with actions or just manually check them from time to time. The latter is not common practice, but given how stable the API is, probably not a huge difference in ultimate outcome.
  • Implementation: presumably we'd want to use a gradual implementation (ie only type hint one submodule at a time, possible thanks to Refactor of labscript.py #102)
  • Minimum python version to support: Since type hinting has been so gradual in python, we'd need to decide what minimum version to support to settle what features we'd actually want to limit ourselves to. Honestly, the more recent the version the better. Py 3.9 is probably a minimum (so we can type hint with list instead of List), 3.10 would be better (for the | Union syntax).
  • Breaking changes: given the age of the API, I suspect enforcing type hints will lead to breaking changes. We'd need to decide how comfortable we are with that in the name of type hinting.

With regards to the final point. The primary breaking hurdle that I am aware of is the labscript convention of providing the variable name to the constructor to bind instances. IE PrawnBlaster('pb', ...) instead of the more expected pb = Prawnblaster(...). As best I can tell, this is simply to allow us to store that name so it can be checked against by other methods (ie calls like parent_device.name). Pretty sure modern python could allow us to turn name into a read-only property that uses introspection to get the variable name and is memoized for better performance. Downside is that I can't think of a reliable way to maintain backwards compatibility, so a lot of downstream code would have to change.

I personally would be much happier making big breaking changes is we had any semblance of unit tests and if we had any other good reasons to break the API.

@dihm dihm added the enhancement New feature or request label Jan 28, 2024
@dihm dihm added the major label Jan 28, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request major
Projects
None yet
Development

No branches or pull requests

1 participant