IElixir
eqwalizer
IElixir | eqwalizer | |
---|---|---|
2 | 11 | |
355 | 500 | |
- | 0.2% | |
5.2 | 8.2 | |
about 1 month ago | 10 days ago | |
Jupyter Notebook | Scala | |
Apache License 2.0 | Apache License 2.0 |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
IElixir
- Elixir Livebook now as a desktop app
-
Niex Interactive Elixir Code Notebooks Written
Instead of adding some functionality for already made https://github.com/pprzetacznik/IElixir, which is full featured kernel for real Jupyter ecosystem (and thus is easy integrated in both notebooks and studios, with running in collab and rendering the n GitHub)....
eqwalizer
-
Switching to Elixir
I don't think the implementation itself is at fault, but yes, I do think that the design of dialyzer makes it an (at times) faulty type checker. The unfortunate reality of a type checker that fails sometimes is that it makes it mostly useless because you can never trust that it'll do the job.
To be clear, I've had it fail in a function where I've literally specced that very function to return a `binary` but I'm returning an `integer` in one of the cases. This is a very shallow context but it can still fail. Now add more functions, maybe one more `case`.
I think an entire rethink of type checking on the BEAM had to be done and that's why eqWalizer[0] was created and why Elixir is looking to add an actual sound, well-developed type checker. Gleam[1] I would assume is just a Hindley-Milner system so that's completely solid. `purerl`[2] is just PureScript for the BEAM so that's also Hindley-Milner, meaning it's solid. `purerl` has some performance issues caused by it compiling down to closures everywhere but if you can pay that cost it's actually pretty fantastic. With that said my bet for the best statically typed experience right now on the BEAM would be `gleam`.
0 - https://github.com/WhatsApp/eqwalizer
1 - https://gleam.run
2 - https://github.com/purerl/purerl
- Unpacking Elixir: Concurrency
-
eqwalizer VS Gradualizer - a user suggested alternative
2 projects | 17 Apr 2023
- Erlang: The coding language that finance forgot
-
Phoenix 1.7 is View-less
While it's not static-typing, compile-time type checking for Erlang have come a long way: Eqwalizer works pretty well - but I may be biased since my employer sponsors the project.
1. https://github.com/WhatsApp/eqwalizer
-
[New] How do you verify program correctness in Elixir?
Note there is also research happening in this area by the Elixir team. The WhatsApp is also working on static types for Erlang, which I am certain will be available for Elixir too at some point.
- Eqwalizer: A Type-Checker for Erlang
- Eqwalizer: WhatsApp’s Erlang Type Checker
-
Elixir Livebook now as a desktop app
From the discord blog posts it seems that elixir powers the chat system, with rust and python as the other two main languages in their stack.
As for whatsapp, they are mainly a erlang shop and yesterday they open sourced a type checker for erlang:
https://github.com/WhatsApp/eqwalizer
What are some alternatives?
Cloudi - A Cloud at the lowest level!
gradient - Gradient is a static typechecker for Elixir
nodefinder - Strategies For Automatic Node Discovery
erllambda - AWS Lambda in Erlang
libcluster - Automatic cluster formation/healing for Elixir applications
explorer - Series (one-dimensional) and dataframes (two-dimensional) for fast and elegant data exploration in Elixir
Kubex - Kubex is the kubernetes integration for Elixir projects and it is written in pure Elixir.
kino - Client-driven interactive widgets for Livebook
ex_aws - A flexible, easy to use set of clients AWS APIs for Elixir
FunkyABX - Audio blind tests
Bonny - The Elixir based Kubernetes Development Framework
Gradualizer - A Gradual type system for Erlang