The Merlin Team is very happy to announce an experimental version of Merlin: Merlin Domains!
As a reminder, Merlin is an editor service that provides advanced IDE features for OCaml. It can be used as a standalone binary or as a library, and is notably used by OCaml LSP Server.In other words, if you are using the OCaml Platform extension with Visual Studio Code, or ocaml-eglot with Emacs, you are already using Merlin under the hood.
Even though over the years we’ve had relatively few complaints about Merlin’s performance, in some contexts (notably very large files), Merlin’s mechanism (parsing file
(with recovery) → typing file
(with recovery) → performing analysis
) could sometimes cause slowdowns!
To address these slowdowns, we started an experimental branch that uses domains and effects, which allow us to interrupt the typing process at the right moment when an analysis request comes in.
In practice, let’s say you run an analysis command on a very large file: the type-checker will progress up to the location that makes the analysis possible, run the analysis phase, return the result, and then continue typing the file. This separation is possible thanks to control flow management enabled by effects, and by having two domains interact with each other.
In practice, this makes the analysis phases much more efficient! We think this is a great example of migrating a regular OCaml application to one that takes advantage of multicore. For a more technical explanation of how this experimental branch works internally, @pitag and @Lyrm will talk about it at Lambda World, in their talk When magic meets multicore - OCaml and its elegant era of parallelism.
Currently, the branch is still in its incubation phase, and we’d be delighted to get your feedback!
How to test the branch
To avoid installing this version of merlin
unintentionally, we suggest pinning this branch in the switches where you want to experiment with this new version (compatible with Merlin’s main
):
opam pin add https://github.com/ocaml/merlin#merlin-domains
Although this experimental branch passes the test-suite, your feedback is very important to help collect potential bugs we may have missed.
We’ve added a Bug/Merlin-domains
label to organize tickets related to this experimental branch.
Next steps
In the future, the goal of this branch (which will be regularly rebased on main
) is to become the main branch, so that all users can benefit from these improvements.
At the same time, the rest of the ecosystem depending on Merlin (such as the OCaml LSP Server) will be adapted to also take full advantage of these new features!
Happy Hacking!
The Merlin Team