2017-02-25 15:27:15 +08:00
[![SpaceVim ](https://spacevim.org/logo.png )](https://spacevim.org)
2017-04-18 18:06:36 +08:00
[Wiki ](https://github.com/SpaceVim/SpaceVim/wiki ) |
2017-02-25 15:27:15 +08:00
[Documentation ](http://spacevim.org/documentation/ ) |
[Twitter ](https://twitter.com/SpaceVim ) |
[Community ](https://spacevim.org/community/ ) |
[Gitter **Chat** ](https://gitter.im/SpaceVim/SpaceVim )
2017-01-10 00:27:52 +08:00
2017-01-08 13:50:17 +08:00
[![Build Status ](https://travis-ci.org/SpaceVim/SpaceVim.svg?branch=dev )](https://travis-ci.org/SpaceVim/SpaceVim)
2017-05-26 20:11:45 +08:00
![Version ](https://img.shields.io/badge/version-0.4.0--dev-FF00CC.svg )
2017-05-01 20:36:41 +08:00
[![MIT License ](https://img.shields.io/badge/license-MIT-blue.svg )](LICENSE)
[![Doc ](https://img.shields.io/badge/doc-%3Ah%20SpaceVim-orange.svg )](doc/SpaceVim.txt)
2017-05-01 14:09:17 +08:00
[![Average time to resolve an issue ](http://isitmaintained.com/badge/resolution/SpaceVim/SpaceVim.svg )](http://isitmaintained.com/project/SpaceVim/SpaceVim "Average time to resolve an issue")
[![Percentage of issues still open ](http://isitmaintained.com/badge/open/SpaceVim/SpaceVim.svg )](http://isitmaintained.com/project/SpaceVim/SpaceVim "Percentage of issues still open")
2017-02-05 10:03:28 +08:00
2017-04-17 22:42:03 +08:00
SpaceVim is a community-driven vim distribution that seeks to provide layer feature, especially for neovim. It offers a variety of layers to choose from. to create a suitable vim development environment, you just need to select the required layers.
2017-02-25 15:53:58 +08:00
See the [documentation ](https://spacevim.org/documentation ) or [the list of layers ](http://spacevim.org/layers/ ) for more information.
2017-01-19 22:08:40 +08:00
2017-02-25 20:45:31 +08:00
Here is a throughput graph of the repository for the last few weeks:
2017-02-25 15:27:15 +08:00
[![Throughput Graph ](https://graphs.waffle.io/SpaceVim/SpaceVim/throughput.svg )](https://waffle.io/SpaceVim/SpaceVim/metrics/throughput)
2017-02-25 19:47:13 +08:00
# Table of Contents
2017-02-25 16:57:35 +08:00
2017-05-30 15:27:03 +08:00
<!-- vim - markdown - toc GFM -->
* [Introduction ](#introduction )
* [Features ](#features )
* [Mnemonic key bindings ](#mnemonic-key-bindings )
* [Unite work flow ](#unite-work-flow )
* [module statusline ](#module-statusline )
* [Install ](#install )
2017-07-20 04:18:22 +08:00
* [1. Requirements ](#1-requirements )
* [2. Install SpaceVim in Linux/Mac ](#2-install-spacevim-in-linuxmac )
* [3. Install SpaceVim in windows ](#3-install-spacevim-in-windows )
2017-05-30 15:27:03 +08:00
* [Update ](#update )
2017-07-21 05:35:34 +08:00
* [Documentation ](#documentation )
* [Quick start guide ](#quick-start-guide )
* [Community ](#community )
2017-05-30 15:27:03 +08:00
* [Support SpaceVim ](#support-spacevim )
* [contribute to SpaceVim ](#contribute-to-spacevim )
* [Write post about SpaceVim ](#write-post-about-spacevim )
* [Credits & Thanks ](#credits--thanks )
<!-- vim - markdown - toc -->
2017-02-10 19:43:38 +08:00
2017-02-25 16:57:35 +08:00
## Introduction
2017-02-05 09:55:10 +08:00
2017-02-25 16:57:35 +08:00
[SpaceVim ](https://github.com/SpaceVim/SpaceVim ) is a community-driven vim distribution with a bundle of modular configuration,
here we call these modules as layers, each layer has different plugins and config, users just need
2017-01-14 13:06:18 +08:00
to select the layers they need. It got inspired by [spacemacs ](https://github.com/syl20bnr/spacemacs ). If you use SpaceVim,
please star it on github. It's a great way of getting feedback and gives me the kick to
put more time into development.
2017-01-04 21:04:42 +08:00
2017-05-24 20:02:46 +08:00
![welcome-page ](https://cloud.githubusercontent.com/assets/13142418/26402270/28ad72b8-40bc-11e7-945e-003f41e057be.png )
2017-02-25 16:57:35 +08:00
2017-05-10 07:17:38 +08:00
If you are new to vim, you should learn about Vim in general, read [vim-galore ](https://github.com/mhinz/vim-galore ).
2017-02-25 16:57:35 +08:00
## Features
2017-01-14 13:06:18 +08:00
2017-02-25 16:57:35 +08:00
- **Great documentation:** access documentation in Vim with
2017-02-25 20:13:39 +08:00
< kbd > :h SpaceVim< / kbd > .
2017-02-25 16:57:35 +08:00
- **Beautiful GUI:** you'll love the awesome UI and its useful features.
- **Mnemonic key bindings:** commands have mnemonic prefixes like
2017-02-25 20:13:39 +08:00
< kbd > [Window]< / kbd > for all the window and buffer commands or < kbd > [Unite]< / kbd > for the
unite work flow commands.
2017-02-25 16:57:35 +08:00
- **Lazy load plugins:** Lazy-load 90% of plugins with [dein.vim]
- **Batteries included:** discover hundreds of ready-to-use packages nicely
2017-02-25 20:13:39 +08:00
organised in configuration layers following a set of
[conventions ](http://spacevim.org/development/ ).
2017-02-25 19:47:13 +08:00
- **Neovim centric:** Dark powered mode of SpaceVim
2016-12-26 23:59:21 +08:00
2017-05-30 15:27:03 +08:00
### Mnemonic key bindings
2017-05-30 15:41:54 +08:00
By default the guide buffer will be displayed 1000ms after the key has been pressed. You can change the delay by setting `'timeoutlen'` option to your liking (the value is in milliseconds).
for example, after pressing `<Space>` in normal mode, you will see :
![mapping-guide ](https://cloud.githubusercontent.com/assets/13142418/25778673/ae8c3168-3337-11e7-8536-ee78d59e5a9c.png )
this guide show you all the available key bindings begin with `[SPC]` , you can type `b` for all the buffer mappings, `p` for project mappings, etc. after pressing `<C-h>` in guide buffer, you will get paging and help info in the statusline.
2017-06-26 23:07:47 +08:00
here is the guide for the default mappings in SpaceVim:
2017-06-27 00:21:49 +08:00
![spc ](https://user-images.githubusercontent.com/13142418/27549426-8141bd86-5ace-11e7-9082-eb86b398acdc.png )
2017-06-26 23:07:47 +08:00
2017-05-30 15:27:03 +08:00
### Unite work flow
2017-03-29 00:27:08 +08:00
2017-05-03 10:55:30 +08:00
![unite ](docs/img/unite_mappings.png )
2017-03-29 00:27:08 +08:00
2017-05-30 15:27:03 +08:00
### module statusline
2017-06-26 23:07:47 +08:00
The `core#statusline` layer provide a heavily customized powerline with the following capabilities:, It is inspired by spacemacs's mode-line. and this layer is loaded by default.
2017-05-30 15:27:03 +08:00
- show the window number
- color code for current state
- show the number of search results
- toggle syntax checking info
- toggle battery info
- toggle minor mode lighters
![search status ](https://cloud.githubusercontent.com/assets/13142418/26313080/578cc68c-3f3c-11e7-9259-a27419d49572.png )
2017-03-29 00:27:08 +08:00
2017-07-21 05:35:34 +08:00
## Install
### 1. Requirements
**nerd fonts and true colors:**
SpaceVim provides basic and awesome mode, if you want to use awesome mode, you need to install the [nerd-fonts ](https://github.com/ryanoasis/nerd-fonts ) and make sure your terminal support [true colors ](https://gist.github.com/XVilka/8346728 ).
**Vim 7.4 above or neovim:**
- [neovim installation ](https://github.com/neovim/neovim/wiki/Installing-Neovim )
- [install vim with python, python3 and lua support ](https://github.com/Valloric/YouCompleteMe/wiki/Building-Vim-from-source )
**git:**
SpaceVim will download all plugins via git.
### 2. Install SpaceVim in Linux/Mac
Install SpaceVim with the command below:
```bash
curl -sLf https://spacevim.org/install.sh | bash
```
After SpaceVim is installed, launch `vim` and SpaceVim will **automatically** install plugins.
for more info about the install script, please check:
```bash
curl -sLf https://spacevim.org/install.sh | bash -s -- -h
```
### 3. Install SpaceVim in windows
- For vim in windows, please just clone this repo as vimfiles in you Home directory.
by default, when open a cmd, the current dir is your Home directory, run this command in cmd.
make sure you have a backup of your own vimfiles. also you need remove `~/_vimrc` in your home directory.
```sh
git clone https://github.com/SpaceVim/SpaceVim.git vimfiles
```
- For neovim in windows, please clone this repo as `AppData\Local\nvim` in your home directory.
for more info, please check out [neovim's wiki ](https://github.com/neovim/neovim/wiki/Installing-Neovim ).
by default, when open a cmd, the current dir is your Home directory, run this command in cmd.
```bash
git clone https://github.com/SpaceVim/SpaceVim.git AppData\Local\nvim
```
## Update
you can update SpaceVim with the command below:
```viml
:SPUpdate SpaceVim
```
2017-02-25 19:47:13 +08:00
## Documentation
2017-02-25 20:13:39 +08:00
### Quick start guide
2017-03-06 23:39:03 +08:00
SpaceVim load custom configuration from `~/.SpaceVim.d/init.vim` ,
2017-02-25 20:13:39 +08:00
:warning: It is not `~/.SpaceVim/init.vim` , user should not change anything in `~/.SpaceVim/` .
here is an example:
2017-05-10 21:00:54 +08:00
```vim
2017-02-25 20:13:39 +08:00
" Here are some basic customizations, please refer to the ~/.SpaceVim.d/init.vim
" file for all possible options:
let g:spacevim_default_indent = 3
let g:spacevim_max_column = 80
" Change the default directory where all miscellaneous persistent files go.
2017-03-20 23:27:24 +08:00
" By default it is ~/.cache/vimfiles/.
let g:spacevim_plugin_bundle_dir = '~/.cache/vimfiles/'
2017-02-25 20:13:39 +08:00
2017-02-25 21:01:05 +08:00
" set SpaceVim colorscheme
2017-07-07 22:08:16 +08:00
let g:spacevim_colorscheme = 'gruvbox'
2017-02-25 21:01:05 +08:00
" Set plugin manager, you want to use, default is dein.vim
let g:spacevim_plugin_manager = 'dein' " neobundle or dein or vim-plug
" Set windows shortcut leader [Window], default is `s`
let g:spacevim_windows_leader = 's'
" Set unite work flow shortcut leader [Unite], default is `f`
let g:spacevim_unite_leader = 'f'
2017-07-07 22:08:16 +08:00
" Set Denite work flow shortcut leader [Denite], default is `F`
let g:spacevim_denite_leader = 'F'
2017-02-25 20:13:39 +08:00
" By default, language specific plugins are not loaded. This can be changed
" with the following, then the plugins for go development will be loaded.
call SpaceVim#layers#load('lang#go')
" loaded ui layer
call SpaceVim#layers#load('ui')
" If there is a particular plugin you don't like, you can define this
" variable to disable them entirely:
let g:spacevim_disabled_plugins=[
\ ['junegunn/fzf.vim'],
\ ]
" If you want to add some custom plugins, use these options:
let g:spacevim_custom_plugins = [
\ ['plasticboy/vim-markdown', {'on_ft' : 'markdown'}],
\ ['wsdjeg/GitHub.vim'],
\ ]
" set the guifont
let g:spacevim_guifont = 'DejaVu\ Sans\ Mono\ for\ Powerline\ 11'
```
2017-02-25 19:47:13 +08:00
Comprehensive documentation is available for each layer by < kbd > :h SpaceVim< / kbd > .
You can also check the [general documentation ](http://spacevim.org/documentation/ ).
## Community
2017-07-21 05:35:34 +08:00
Try these SpaceVim hangouts for any questions, problems or comments.
2017-02-10 19:43:38 +08:00
- Chat
- [![Gitter ](https://badges.gitter.im/SpaceVim/SpaceVim.svg )](https://gitter.im/SpaceVim/SpaceVim?utm_source=badge& utm_medium=badge& utm_campaign=pr-badge)
- [![QQ ](https://img.shields.io/badge/QQ群-121056965-blue.svg )](https://jq.qq.com/?_wv=1027& k=43DB6SG)
- [![Facebook ](https://img.shields.io/badge/FaceBook-SpaceVim-blue.svg )](https://www.facebook.com/SpaceVim)
2017-07-21 05:35:34 +08:00
- Ask
- [issue tracker ](https://github.com/SpaceVim/SpaceVim/issues ) for issue and feature requests
- vi StackExchange for "how to" & configuration questions
- [![Twitter Follow ](https://img.shields.io/twitter/follow/SpaceVim.svg?style=social&label=Follow&maxAge=2592000 )](https://twitter.com/SpaceVim) for hugs & pithy comments
2017-02-10 19:43:38 +08:00
- Discuss
2017-03-06 20:23:48 +08:00
- [google mailing list ](https://groups.google.com/forum/#!forum/spacevim )
2017-02-10 19:43:38 +08:00
2017-02-21 21:21:04 +08:00
2017-02-25 19:47:13 +08:00
## Support SpaceVim
2017-02-10 19:43:38 +08:00
2017-02-25 20:45:31 +08:00
The best way to support SpaceVim is to contribute to it either by reporting bugs, helping the community on the Gitter Chat or sending pull requests.
If you want to show your support financially you can contribute to [Bountysource ](https://www.bountysource.com/teams/spacevim ) or buy a drink for the maintainer by clicking following icon.
2017-03-06 23:39:03 +08:00
< a href = 'https://ko-fi.com/A538L6H' target = '_blank' > < img height = '36' style = 'border:0px;height:36px;' src = 'https://az743702.vo.msecnd.net/cdn/kofi4.png?v=f' border = '0' alt = 'Buy Me a Coffee at ko-fi.com' / > < / a >
2017-02-25 20:45:31 +08:00
2017-03-06 23:39:03 +08:00
If you used SpaceVim in a project and you want to show that fact, you can use the SpaceVim badge:
2017-02-25 20:45:31 +08:00
[![ ](https://spacevim.org/img/build-with-SpaceVim.svg )](https://spacevim.org)
2017-02-10 19:43:38 +08:00
2017-02-25 20:45:31 +08:00
markdown
2017-07-21 05:35:34 +08:00
```markdown
2017-02-25 20:45:31 +08:00
[![ ](https://spacevim.org/img/build-with-SpaceVim.svg )](https://spacevim.org)
```
2017-02-10 19:43:38 +08:00
2017-02-25 19:47:13 +08:00
### contribute to SpaceVim
2017-02-25 21:23:27 +08:00
Before contributing be sure to consult the [contribution guidelines ](http://spacevim.org/development/#contribution-guidelines ) and [conventions ](http://spacevim.org/development/#conventions ).
2017-02-25 20:45:31 +08:00
2017-02-25 19:47:13 +08:00
### Write post about SpaceVim
2017-02-10 19:43:38 +08:00
2017-07-21 05:35:34 +08:00
if you want to write something about SpaceVim, and want your post to be posted in [SpaceVim's blog page ](https://spacevim.org/blog ), please show us the link.
2017-02-25 21:01:05 +08:00
2017-02-25 20:45:31 +08:00
2017-02-25 19:47:13 +08:00
## Credits & Thanks
2017-07-21 05:35:34 +08:00
2017-02-10 19:43:38 +08:00
- [![GitHub contributors ](https://img.shields.io/github/contributors/SpaceVim/SpaceVim.svg )](https://github.com/SpaceVim/SpaceVim/graphs/contributors)
- [vimdoc ](https://github.com/google/vimdoc ) generate doc file for SpaceVim
- [Rafael Bodill ](https://github.com/rafi ) and his vim-config
- [Bailey Ling ](https://github.com/bling ) and his dotvim
2017-07-21 05:35:34 +08:00
- authors of all the plugins used in SpaceVim.