2017-12-19 09:31:58 +08:00
---
title: "SpaceVim golang layer"
description: "This layer is for golang development. It also provides additional language-specific key mappings."
---
2018-06-23 14:37:41 +08:00
# [Available Layers](../../) >> lang#go
2017-12-19 09:31:58 +08:00
<!-- vim - markdown - toc GFM -->
- [Description ](#description )
2018-01-03 22:56:15 +08:00
- [Features ](#features )
2022-05-27 11:50:39 +08:00
- [Install ](#install )
2022-05-27 11:48:19 +08:00
- [Layer options ](#layer-options )
2017-12-19 09:31:58 +08:00
- [Key bindings ](#key-bindings )
<!-- vim - markdown - toc -->
## Description
2022-05-27 11:48:19 +08:00
This layer is for [golang ](https://go.dev/ ) development. It also provides additional language-specific key mappings.
2017-12-19 09:31:58 +08:00
2022-05-27 11:50:39 +08:00
## Features
- auto-completion
- syntax checking
- goto definition
- reference finder
2017-12-19 09:31:58 +08:00
## Install
2021-06-21 20:39:29 +08:00
To use this configuration layer, update your custom configuration file with:
2018-06-23 14:37:41 +08:00
```toml
[[layers]]
name = "lang#go"
```
2018-01-03 22:56:15 +08:00
2019-03-18 07:45:39 +08:00
After the installation, run `:GoInstallBinaries` inside vim.
2019-05-08 09:29:54 +08:00
To enable tagbar support, you need to install [gotags ](https://github.com/jstemmer/gotags ):
```sh
2021-10-01 14:30:03 +08:00
go install github.com/jstemmer/gotags@latest
2019-05-08 09:29:54 +08:00
```
2022-05-27 11:48:19 +08:00
## Layer options
2022-05-27 12:12:30 +08:00
- `enabled_linters` : set a list of enabled lint for golang. by default this
option is `['golint']` . The available linters includes: `go` , `gometalinter`
- `go_file_head` : the default file head for golang source code.
```
[[layers]]
name = "lang#go"
go_file_head = [
'#!/usr/bin/python3',
'# -*- coding : utf-8 -*-'
''
]
```
- `go_interpreter` : Set the interpreter of go.
```
[[layers]]
name = 'lang#go'
go_interpreter = '~/download/bin/go'
```
- `format_on_save` : enable/disable code formation when save go file. This
options is disabled by default, to enable it:
```
[[layers]]
name = 'lang#go'
format_on_save = true
```
2022-05-27 11:48:19 +08:00
2017-12-19 09:31:58 +08:00
## Key bindings
2017-12-19 16:23:46 +08:00
**Import key bindings:**
2022-10-21 12:05:12 +08:00
| Key Bindings | Descriptions |
| ------------ | ---------------------------------------------- |
| `SPC l a` | go alternate |
| `SPC l b` | go build |
| `SPC l c` | go coverage |
| `SPC l d` | go doc |
| `SPC l D` | go doc vertical |
| `SPC l e` | go rename |
| `SPC l g` | go definition |
| `SPC l G` | go generate |
| `SPC l h` | go info |
| `SPC l i` | go implements |
| `SPC l I` | implement stubs |
| `SPC l k` | add tags |
| `SPC l K` | remove tags |
| `SPC l l` | list declarations, need `ctrlp` or `fzf` layer |
| `SPC l m` | format imports |
| `SPC l M` | add import |
| `SPC l r` | go run |
| `SPC l s` | fill struct |
| `SPC l t` | go test |
| `SPC l v` | freevars |
| `SPC l x` | go referrers |
2017-12-19 16:23:46 +08:00
**Code formatting:**
2022-05-27 11:50:39 +08:00
the default key bindings for formatting current buffer is `SPC b f` , and this key bindings is defined in [format layer ](../../format/ ). You can also use `g=` to indent current buffer.
2017-12-19 16:23:46 +08:00
2017-12-19 16:42:29 +08:00
To make neoformat support go files, you should have [go-fmt ](http://golang.org/cmd/gofmt/ ) command available, or
install [goimports ](https://godoc.org/golang.org/x/tools/cmd/goimports ). `go-fmt` is delivered by golang's default installation, so make sure you have correctly setup your go environment.