mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-01-24 03:00:06 +08:00
98 lines
2.6 KiB
Markdown
98 lines
2.6 KiB
Markdown
---
|
|
title: "SpaceVim lang#elm layer"
|
|
description: "This layer is for Elm development, provide autocompletion, syntax checking, code format for Elm file."
|
|
image: https://user-images.githubusercontent.com/13142418/44625046-7b2f7700-a931-11e8-807e-dba3f73c9e90.png
|
|
---
|
|
|
|
# [Available Layers](../../) >> lang#elm
|
|
|
|
<!-- vim-markdown-toc GFM -->
|
|
|
|
- [Description](#description)
|
|
- [Features](#features)
|
|
- [Install](#install)
|
|
- [Requirements](#requirements)
|
|
- [Layer](#layer)
|
|
- [Key bindings](#key-bindings)
|
|
- [Language specific key bindings](#language-specific-key-bindings)
|
|
- [Inferior REPL process](#inferior-repl-process)
|
|
|
|
<!-- vim-markdown-toc -->
|
|
|
|
## Description
|
|
|
|
This layer is for Elm development.
|
|
|
|
## Features
|
|
|
|
- Code completion
|
|
- Syntax highlighting, indent
|
|
- Running unite test
|
|
- Syntax checking
|
|
- Find symbol doc
|
|
|
|
SpaceVim also provides REPL support for Elm.
|
|
|
|
## Install
|
|
|
|
### Requirements
|
|
|
|
First, make sure you have the [Elm Platform](http://elm-lang.org/install) installed. The simplest method to get started is to use the official [npm](https://www.npmjs.com/package/elm) package.
|
|
|
|
```sh
|
|
npm install -g elm
|
|
```
|
|
|
|
In order to run unit tests from within vim, install [elm-test](https://github.com/rtfeldman/node-elm-test)
|
|
|
|
```sh
|
|
npm install -g elm-test
|
|
```
|
|
|
|
For code completion and doc lookups, install [elm-oracle](https://github.com/elmcast/elm-oracle).
|
|
|
|
```sh
|
|
npm install -g elm-oracle
|
|
```
|
|
|
|
To automatically format your code, install [elm-format](https://github.com/avh4/elm-format).
|
|
|
|
```sh
|
|
npm install -g elm-format
|
|
```
|
|
|
|
### Layer
|
|
|
|
To use this configuration layer, update custom configuration file with:
|
|
|
|
```toml
|
|
[[layers]]
|
|
name = "lang#elm"
|
|
```
|
|
|
|
## Key bindings
|
|
|
|
### Language specific key bindings
|
|
|
|
| key bindings | Descriptions |
|
|
| --------------- | -------------------------- |
|
|
| `SPC l d` / `K` | Show doc of cursor symbol |
|
|
| `SPC l m` | Compile the current buffer |
|
|
| `SPC l t` | Runs the tests |
|
|
| `SPC l e` | Show error detail |
|
|
| `SPC l w` | Browse symbol doc |
|
|
|
|
### Inferior REPL process
|
|
|
|
Start a `elm repl` inferior REPL process with `SPC l s i`.
|
|
|
|
![elm repl](https://user-images.githubusercontent.com/13142418/44625046-7b2f7700-a931-11e8-807e-dba3f73c9e90.png)
|
|
|
|
Send code to inferior process commands:
|
|
|
|
| key bindings | Descriptions |
|
|
| ----------- | ------------------------------------------------ |
|
|
| `SPC l s b` | send buffer and keep code buffer focused |
|
|
| `SPC l s l` | send line and keep code buffer focused |
|
|
| `SPC l s s` | send selection text and keep code buffer focused |
|