2017-12-21 21:38:47 +08:00
---
title: "SpaceVim lang#lua layer"
description: "This layer is for lua development, provide autocompletion, syntax checking, code format for lua file."
---
# [SpaceVim Layers:](https://spacevim.org/layers) lang#lua
<!-- vim - markdown - toc GFM -->
2017-12-29 12:25:56 +08:00
* [Description ](#description )
* [Installation ](#installation )
* [Layer ](#layer )
* [Syntax checking && Code formatting ](#syntax-checking--code-formatting )
* [Key bindings ](#key-bindings )
* [Inferior REPL process ](#inferior-repl-process )
* [Running current script ](#running-current-script )
2017-12-21 21:38:47 +08:00
<!-- vim - markdown - toc -->
## Description
This layer is for lua development.
## Installation
### Layer
To use this configuration layer, add `SPLayer 'lang#lua'` to your custom configuration file.
### Syntax checking && Code formatting
## Key bindings
### Inferior REPL process
2017-12-29 12:29:27 +08:00
Start a `lua` or `luap` inferior REPL process with `SPC l s i` . You may change the REPL command by layer option `repl_command` . For example, if you want to use `lua.repl` , load this layer via:
2017-12-21 21:38:47 +08:00
```vim
call SpaceVim#layers#load('lang#lua'
\ {
\ 'repl_command' : '~/.luarocks/lib/luarocks/rocks-5.3/luarepl/0.8-1/bin/rep.lua',
\ }
```
Send code to inferior process commands:
| Key Binding | Description |
| ----------- | ------------------------------------------------ |
2017-12-29 12:25:56 +08:00
| `SPC l b` | compile current lua buffer |
| `SPC l r` | run current lua file |
2017-12-29 12:28:17 +08:00
| `SPC l f` | format current lua file |
2017-12-21 21:38:47 +08:00
| `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 |
### Running current script
To running a ruby script, you can press `SPC l r` to run current file without loss focus, and the result will be shown in a runner buffer.