aleksanb | 10 months ago | on: Pyrefly: A new type checker and IDE experience for Python
aleksanb's comments
aleksanb | 10 months ago | on: Ty: A fast Python type checker and language server
The reason we're stuck on mypy at work is because it's the only type checker that has a plugin for Django that properly manages to type check its crazy runtime generated methods.
I wish more python tooling took the TS approach of "what's in the wild IS the language", as opposed to a "we only typecheck the constructs we think you SHOULD be using".
aleksanb | 1 year ago | on: EU to take action to protect children from harmful practices in video games
Most newer blizzard games will get a lot better due to this!
aleksanb | 1 year ago | on: "We're building a new static type checker for Python"
All type checkers other than mypy (e.g. pyright, intellij) have ignored the level of plugin support necessary to make django work well, and so they are DOA for any large existing django codebase. Unless ruff decides to support such a dynamic interface as mypy's, it'll fare no better.
We use mypy with [django-stubs](https://github.com/typeddjango/django-stubs) which works ok nowadays.
There was an effort to create a typechecking plugin interface for dataclass-style transforms for python type checkers, but what was merged was so lacking that one couldn't even make something close to django-stubs with it.
aleksanb | 1 year ago | on: Researchers discover potentially catastrophic exploit present in AMD chips
As this bug now has become known to always have been there, i could probably force amd to replace my 3900x if they don't provide software patches.
Has anyone else attempted a similar RTM for software defects?
aleksanb | 2 years ago | on: Stop Building Stingy Apps
Users must be able to get their own data exported, in some useful format.
aleksanb | 2 years ago | on: Mypy 1.6
Here's our plugin setup in mypy.ini in case this helps (Django 4.2 + drf 3.14)
[mypy]
plugins =
mypy_django_plugin.main,
mypy_drf_plugin.main
ignore_missing_imports = True
follow_imports = silent
no_implicit_optional = True
warn_unused_ignores = True
check_untyped_defs = True
disallow_untyped_defs = True
disallow_untyped_calls = True
warn_unreachable = True
strict_equality = True
allow_redefinition = True
show_error_codes = True
mypy_path = stubs
[mypy.plugins.django-stubs]
django_settings_module = 'mycompany.settings'
with packages: mypy==1.6.0
django-stubs==4.2.4
django-stubs-ext==4.2.2
djangorestframework-stubs==3.14.3
with this horror of a regex in make (because you'll get drowned in wrong type errors in all of the untype files, and errors get shown from imports even if you don't care about that imported file), add more file targets as necessary: FILES_TO_MYPY = $(shell ls mycompany/\*/validators.py mycompany/\*/services.py mycompany/\*/selectors.py mycompany/\*/managers.py | sort | uniq)
# 1)We have to grep out django-manager-missing like this until the following bug
# is fixed: https://github.com/python/mypy/issues/12987.
# 2) We grep out the line of `Found 95 errors in 16 files (checked 83 source
# files)` that now appears as we use follow-imports: silent, because there's a
# bug where errors from imported modules are counted against the total even
# though they aren't emitted. If any real errors appear we get them as a
# separate line anyways.
.PHONY: mypy
mypy:
@{ MYPY_FORCE_COLOR=${NOT_CI} $(VENV)/bin/mypy --config-file mypy.ini $(FILES_TO_MYPY) 2>&3 | grep -v 'django-manager-missing\|errors in'; } 3>&1 | tee $(HYRE_TESTS_OUTPUT_PATH)/mypy.stdout.txt
This allows you to get proper errors for things like model = MyModel.objects.get()
othermodel = model.othermodel_set.first()
reveal_type(othermodel) # correctly revealed to note: Revealed type is "Union[mycompany.importpath.models.OtherModel None]"
and even errors on typos like model = MyModel.objects.get()
othermodel = model.ooooothermodel_set.first() # revealed as MyModel has no attribute ooooothermodel_set, perhaps you ment othermodel_set
.aleksanb | 2 years ago | on: Mypy 1.6
We use mypy + [django-stubs](https://github.com/typeddjango/django-stubs) (in a huge Django + drf project at day job) which includes a plugin for mypy allowing it to recognize all reverse relations and manager methods. Mypy is still really rough around the edges. The cli args are poorly documented, and how they correspond to declarations in a mypy.ini / pyproject.toml is mysterious. Match-statements still have bugs even a year after release. Exclusion of untyped / partially typed files and packages we've had to solve with grep filtering mypy's output for our whitelisted set of files, as it's been unable to separate properly between errors you care about (in your own codebase) and errors in others code (dependencies, untypable dynamic python packages etc).
The largest issue IMO is that mypy tried to adapt a java / OOP style way of type system onto python, instead of recognizing the language's real power within duck typing and passing structural types around. Typescript chose the right approach here, modelling javascript the way it is actually written, favoring structural over nominal typing, instead of the archaic and now left-behind way of Java-style OOP that has influenced mypy.
There was a recently accepted PEP which allowed for limited dataclass transforms, enough to cover the @attr.s usecase for both mypy and pyright, but nowhere near expressive enough to cover django's models and ORM sadly. It's probably impossible / undesirable to allow for such rich plugins, so i see the future for proper pluginless typing to be more akin to how pydantic / normal dataclasses solve typing, by starting with a specification of the types, deriving its runtime implementation, instead of plugins having to reverse the type representation of a custom DSL.
aleksanb | 3 years ago | on: I spent a year designing a low profile, minimal mechanical keyboard
- low profile, fantastic
- not full size. Numpads only get in the way!
- mechanical keys
- rotary encoder. Useful for everything! Fl studio, moving pixels in vegas, audio knob etc.
- i don’t mind the font, but perhaps a version without any typography would be nice.
I hope they’ll ship to Norway.
aleksanb | 5 years ago | on: Salesforce Signs Definitive Agreement to Acquire Slack
aleksanb | 8 years ago | on: Giving you more characters
aleksanb | 9 years ago | on: Nin is a tool for development of browser-based WebGL demos
View in chrome with webgl on for the best experience, or on your iPhone if you have a newer one!
aleksanb | 9 years ago | on: Ask HN: What is your favorite Google chrome extension?
aleksanb | 9 years ago | on: This JPEG is also a webpage
You can see the final packed .PNG results here: Crankwork Steamfist https://stianj.com/crankwork-steamfist/, Everything is Fashion https://stianj.com/fashion/, and Inakuwa Oasis http://arkt.is/inakuwa-oasis/.
The tool used for creating both the demos and the packed .PNG is made by us and available on GitHub here https://github.com/ninjadev/nin/.
aleksanb | 9 years ago | on: Scalable Live Video Streaming Using NGINX and MPEG-DASH/HLS
aleksanb | 11 years ago | on: FPGA Programming: Where to Begin? (2012)
All of us came from software backgrounds, never having touched any hardware description language.
To get started I'd recommend reading Computer organization and design by Patterson and Hennessy (http://www.amazon.com/Computer-Organization-Design-Fifth-Edi...).
For the VHDL part, all we had available was this small basic VHDL compendium (not sure if I can redistribute it), open source github repositories from friends and classmates, as well as the always helpful vhdlguru.blogspot.com
So i'll reccomend following one of the open lecture series posted above :)
aleksanb | 11 years ago | on: Show HN: Open source hardware platform for Bluetooth hacking
We hope to create a community around BLE devices where developers share their ideas designs with each other. Everything is open-source, of course, with lots of supporting materials, together with companion apps for both Android and iOS.
The way these type checkers get fast is usually by not supporting the crazy rich reality of realworld python code.
The reason we're stuck on mypy at work is because it's the only type checker that has a plugin for Django that properly manages to type check its crazy runtime generated methods.
I wish more python tooling took the TS approach of "what's in the wild IS the language", as opposed to a "we only typecheck the constructs we think you SHOULD be using".