ML-flavoured Erlang v0.2.0 is now ready for use. This version includes a couple of major missing pieces from the first v0.1.0 release including:
- support for maps, both constructing literal maps and pattern matching
- binary support
- UTF-8 binary strings
This release also includes some very early support for writing unit tests inside the modules they’re concerned with and running them via EUnit and rebar3 with the help of Tristan Sloughter’s plugin. If you’re using the plugin, you’ll be able to run tests defined in
.mlfe files with
Here’s the example module from the new tour of the language:
module my_module // one function that takes a single argument will be publicly accessible: export double/1 /* Our double function defines an "add" function inside of itself. Comments for now are C-style. */ double x = let add a b = a + b in add x x test "doubling 2 is 4" = some_test_checker (double 2) 4 // Basic ADT with type constructors: type even_or_odd = Even int | Odd int // A function from integers to our ADT: even_or_odd x = let rem = x % 2 in match rem with 0 -> Even x | _ -> Odd x
The full changelog is available here and there’s a new language tour document available that explains the use of the language in a little more detail for anyone new to it.
For version 0.3.0 my main goals are:
- probable project rename
- type annotations/ascriptions
- records. I’d like some basic row polymorphism here (I believe this fits with records in OCaml and Elm) but need to do some more reading and research. In all likelihood records will get syntax similar to OCaml’s and be compiled as Erlang maps to start.
- quoted atoms
- do notation/side effects
Contributing and Discussing
Contributions are welcome subject to the licence and code of conduct as specified in the project repository. Please join the IRC channel
#mlfe on freenode for help or general discussion (governed by the same code of conduct as the project). I’m on IRC as
j14159 and Twitter with the same username.