Instructions to get started with Elm tooling in Vim.
Install elm-language-server
and its dependencies. It provides most features, e.g. diagnostics (elm make
), linting (elm-analyse
), jump to definition, formatting (elm-format
) and more. It is a standalone implementation of the language server protocol (LSP). There exist multiple language server client implementations (e.g. CoC or ale).
- CoC.nvim (recommended): Install
CoC
. Look into elm-language-server README orCoC
wiki for setup and usage instructions. - ale: Install
ale
and useelm_ls
linter. Seeelm-language-server
README,ale
README andale
docs for usage instructions. - LanguageClient-neovim: Install
LanguageClient-neovim
and see elm-language-server README.
If you have Vim/Neovim > 8.2 patch 929, Elm syntax is already included in Vim!
Otherwise install elm-vim-syntax
to add syntax highlighting and indentation.
elm-format
is used by elm-language-server
to format code. An alternative is ale
's elm-format
fixer.
elm-analyse
is used by elm-language-server
for static code analysis of elm code. It doesn't need to be installed manually. Its checks can be configured.
elm-language-server
provides snippets (e.g. with CoC
).
An alternative is to install Ultisnips
for snippet functionality. Install honza/vim-snippets
which contains elm.snippets
Install vim-test
to run tests. It contains elmtest.vim
. :TestFile
will execute elm-test
.
Install majutsushi/tagbar
and configure content displayed in the tagbar.
let g:tagbar_type_elm = {
\ 'kinds' : [
\ 'f:function:0:0',
\ 'm:modules:0:0',
\ 'i:imports:1:0',
\ 't:types:1:0',
\ 'a:type aliases:0:0',
\ 'c:type constructors:0:0',
\ 'p:ports:0:0',
\ 's:functions:0:0',
\ ]
\}
There is an example configuration to showcase a small Vim setup for Elm.
It's a good idea to take a look how others are configuring their environments. Here are some examples:
andys8/dotfiles
Augustin82/vim
antoine-atmire/vim-elmc
pehota/dotfiles
hulufei/dotfiles
Miaxos/Home-
leojpod/dotfiles
Frequently asked questions. Feel free to contribute.
Start with the official CoC example configuration
. Then start to look into our example configuration and user configurations. It'll take some time and tweaking until you find a configuration that's perfect for you.
Add "coc.preferences.formatOnSaveFiletypes": ["elm"]
to coc-settings.json
.
With CoC you can use :CocInfo
to see all client/server messages or :CocOpenLog
to show the log. Set elmLS.trace.server
to verbose
. Make sure you're using a valid elm project with an elm.json
file or verify behavior with elm-spa-example
.
CoC uses floating windows to display diagnostics (error messages). By default only the first 8 lines are shown.
- Raise maximum number of error lines displayed with
diagnostic.maxWindowHeight
- Disable floating window and use
diagnostic.messageTarget
"echo"
instead - Look into how to scroll inside the floating window.
It's possible to configure when elm-analyse
will be triggered or disable it with config "elmAnalyseTrigger": "never"
. See "server settings".
Add a elm-analyse.json
config file like this and add check names.
{
"checks": {
"UnusedTypeAlias": false
}
}
ElmCast/elm-vim
an older vim plugin people used before there existed a language server implementation. We're grateful it existed in the past, but seems to be unmaintained and isn't necessary anymore.
Zaptic/elm-vim
is a maintained fork. It can be a simple alternative to the elm-language-server
with fewer features and easier setup.