1
0
mirror of https://github.com/SpaceVim/SpaceVim.git synced 2025-01-23 13:10:04 +08:00
SpaceVim/docs/development.md

330 lines
12 KiB
Markdown
Raw Normal View History

2017-02-12 16:36:17 +08:00
---
title: "Development"
2017-12-09 13:33:16 +08:00
description: "Development information about SpaceVim, including contributing guidelines and changelog."
2017-02-12 16:36:17 +08:00
---
2017-03-01 23:15:00 +08:00
# Development
2017-02-07 01:51:23 +08:00
2017-12-09 13:33:16 +08:00
<!-- vim-markdown-toc GFM -->
2017-03-02 20:17:13 +08:00
- [Contribution guidelines](#contribution-guidelines)
2017-12-09 13:33:16 +08:00
- [Asking for help](#asking-for-help)
- [Reporting issues](#reporting-issues)
- [Contributing code](#contributing-code)
- [License](#license)
- [Conventions](#conventions)
- [Pull Request](#pull-request)
- [Ideally for simple PRs (most of them):](#ideally-for-simple-prs-most-of-them)
- [For complex PRs (big refactoring, etc):](#for-complex-prs-big-refactoring-etc)
- [Contributing a layer](#contributing-a-layer)
- [File header](#file-header)
- [Author of a new layer](#author-of-a-new-layer)
- [Contributor to an existing layer](#contributor-to-an-existing-layer)
- [Contributing a keybinding](#contributing-a-keybinding)
2018-01-02 20:00:16 +08:00
- [Language specified key bindings](#language-specified-key-bindings)
2017-12-09 13:33:16 +08:00
- [Contributing a banner](#contributing-a-banner)
2017-03-02 22:20:46 +08:00
- [Build with SpaceVim](#build-with-spacevim)
- [Changelog](#changelog)
2017-03-02 20:17:13 +08:00
2017-12-09 13:33:16 +08:00
<!-- vim-markdown-toc -->
Development happens in the GitHub repository. here is a throughput graph of the repository for the last few weeks:
[![Throughput Graph](https://graphs.waffle.io/SpaceVim/SpaceVim/throughput.svg)](https://waffle.io/SpaceVim/SpaceVim/metrics/throughput)
2017-02-25 21:23:27 +08:00
## Contribution guidelines
SpaceVim is an effort of all the volunteers, we encourage you to pitch in. The community makes SpaceVim what it is.
2017-03-02 20:17:13 +08:00
We have a few guidelines, which we ask all contributors to follow.
You can only consider reading the sections relevant to what you are going to do:
- [Asking for help](#asking-for-help) if you are about to open an issue to ask a question.
- [Reporting issues](#reporting-issues) if you are about to open a new issue.
- [Contributing code](#contributing-code) if you are about to send a pull-request.
2017-03-02 20:17:13 +08:00
### Asking for help
If you want to ask an usage question, be sure to look first into some places as it may hold the answers:
2017-12-09 13:33:16 +08:00
2017-03-02 22:20:46 +08:00
- <kbd>:h SpaceVim-faq</kbd>: Some of the most frequently asked questions are answered there.
- [SpaceVim documentation](https://spacevim.org/documentation): It is the general documentation of SpaceVim.
2017-03-02 20:17:13 +08:00
### Reporting issues
Issues have to be reported on [issues tracker](https://github.com/SpaceVim/SpaceVim/issues), Please:
2017-12-09 13:33:16 +08:00
- Check that there is no duplicate issue in the issues tracker, you can search for keywords in the issues tracker.
2017-03-02 20:17:13 +08:00
- Check that the issue has not been fixed in latest version of SpaceVim, please update your SpaceVim, and try to reproduce the bug here.
- Use a clear title and follow the issue template.
- Include details on how to reproduce it, just like a step by step guide.
### Contributing code
2017-03-02 22:20:46 +08:00
Code contributions are welcome. Please read the following sections carefully. In any case, feel free to join us on the [gitter chat](https://gitter.im/SpaceVim/SpaceVim) to ask questions about contributing!
2017-02-25 21:23:27 +08:00
2017-03-02 22:20:46 +08:00
#### License
2017-02-07 01:51:23 +08:00
2017-03-02 22:20:46 +08:00
The license is MIT for all the parts of SpaceVim. this includes:
2017-12-09 13:33:16 +08:00
2017-03-02 22:20:46 +08:00
- The initialization and core files
- All the layer files.
2017-02-07 01:51:23 +08:00
2017-03-02 22:20:46 +08:00
For files not belonging to Spacemacs like local packages and libraries, refer to the header file. Those files should not have an empty header, we may not accept code without a proper header file.
#### Conventions
2018-01-18 21:19:05 +08:00
SpaceVim is based on conventions, mainly for naming functions, keybindings definition and writing documentation. Please read the [conventions](https://spacevim.org/conventions/) before your first contribution to get to know them.
2017-03-02 22:20:46 +08:00
#### Pull Request
Submit your contribution against the `dev` branch. You should not use your master branch to modify SpaceVim, this branch is considered to be read-only.
You may want to read our beginners guide for Pull Requests.
PR = Pull-Request
##### Ideally for simple PRs (most of them):
2018-01-20 16:39:54 +08:00
- Branch from `master`
2017-03-02 22:20:46 +08:00
- One topic per PR
- One commit per PR
- If you have several commits on different topics, close the PR and create one PR per topic
- If you still have several commits, squash them into only one commit
- Rebase your PR branch on top of upstream develop before submitting the PR
Those PRs are usually cherry-picked.
##### For complex PRs (big refactoring, etc):
Squash only the commits with uninteresting changes like typos, syntax fixes, etc… and keep the important and isolated steps in different commits.
Those PRs are merged and explicitly not fast-forwarded.
2018-01-20 16:39:54 +08:00
2017-03-02 22:20:46 +08:00
Commit messages
Write commit messages according to adapted [Tim Popes guidelines](http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html):
- Use present tense and write in the imperative: “Fix bug”, not “fixed bug” or “fixes bug”.
- Start with a capitalized, short (72 characters or less) summary, followed by a blank line.
- If necessary, add one or more paragraphs with details, wrapped at 72 characters.
- Separate paragraphs by blank lines.
This is a model commit message:
2018-01-02 20:00:16 +08:00
```gitcommit
Capitalized, short (72 chars or less) summary
2017-03-02 22:20:46 +08:00
2018-01-02 20:00:16 +08:00
More detailed explanatory text, if necessary. Wrap it to about 72
characters or so. In some contexts, the first line is treated as the
subject of an email and the rest of the text as the body. The blank
line separating the summary from the body is critical (unless you omit
the body entirely); tools like rebase can get confused if you run the
two together.
2017-03-02 22:20:46 +08:00
2018-01-02 20:00:16 +08:00
Write your commit message in the imperative: "Fix bug" and not "Fixed bug"
or "Fixes bug." This convention matches up with commit messages generated
by commands like git merge and git revert.
2017-03-02 22:20:46 +08:00
2018-01-02 20:00:16 +08:00
Further paragraphs come after blank lines.
2017-03-02 22:20:46 +08:00
2018-01-02 20:00:16 +08:00
- Bullet points are okay, too
2017-03-02 22:20:46 +08:00
2018-01-02 20:00:16 +08:00
- Typically a hyphen or asterisk is used for the bullet, followed by a
single space, with blank lines in between, but conventions vary here
2017-03-02 22:20:46 +08:00
2018-01-02 20:00:16 +08:00
- Use a hanging indent
```
2017-03-02 22:20:46 +08:00
[Gita] provide vim mode for Git commit messages, which helps you to comply to these guidelines.
#### Contributing a layer
Please read the layers documentation first.
Layer with no associated configuration will be rejected. For instance a layer with just a package and a hook can be easily replaced by the usage of the variable `g:spacevim_custom_plugins`.
##### File header
The file header for vim script should look like the following template:
```viml
"=============================================================================
" FILENAME --- NAME layer file for SpaceVim
" Copyright (c) 2012-2016 Shidong Wang & Contributors
2018-01-02 20:00:16 +08:00
" Author: YOUR NAME <YOUR EMAIL>
2017-03-02 22:20:46 +08:00
" URL: https://spacevim.org
" License: MIT license
"=============================================================================
```
2018-01-02 20:00:16 +08:00
You should replace FILENAME by the name of the file (e.g. foo.vim) and NAME by the name of the layer you are creating, dont forget to replace **YOUR NAME** and **YOUR EMAIL** also.
2017-03-02 22:20:46 +08:00
##### Author of a new layer
In the files header, change the default author name (Shidong Wang) to your name.
here is an example for creating a new layer names `foo`:
2017-02-10 22:05:19 +08:00
1. fork SpaceVim repo
2. add a layer file `autoload/SpaceVim/layers/foo.vim` for `foo` layer.
3. edit layer file, check out the example below:
```vim
2017-03-02 22:20:46 +08:00
"=============================================================================
" foo.vim --- foo Layer file for SpaceVim
" Copyright (c) 2012-2016 Shidong Wang & Contributors
" Author: Shidong Wang < wsdjeg at 163.com >
" URL: https://spacevim.org
" License: MIT license
"=============================================================================
""
" @section foo, layer-foo
" @parentsection layers
" This the doc for this layer:
"
2018-01-03 23:14:15 +08:00
" @subsection Key Bindings
2017-03-02 22:20:46 +08:00
" >
" Mode Key Function
" -------------------------------------------------------------
" normal <leader>jA generate accessors
" normal <leader>js generate setter accessor
" <
2018-01-03 23:14:15 +08:00
" @subsection Layer options
2017-03-02 22:20:46 +08:00
" >
" Name Description Default
" -------------------------------------------------------------
2018-01-03 23:14:15 +08:00
" option1 Set option1 for foo layer ''
" option2 Set option2 for foo layer []
" option3 Set option3 for foo layer {}
" <
" @subsection Global options
" >
" Name Description Default
" -------------------------------------------------------------
" g:pluginA_opt1 Set opt1 for plugin A ''
" g:pluginB_opt2 Set opt2 for plugin B []
2017-03-02 22:20:46 +08:00
" <
2017-02-10 22:05:19 +08:00
function! SpaceVim#layers#foo#plugins() abort
2017-03-02 22:20:46 +08:00
let plugins = []
call add(plugins, ['Shougo/foo.vim', {'option' : 'value'}])
call add(plugins, ['Shougo/foo_test.vim', {'option' : 'value'}])
return plugins
2017-02-10 22:05:19 +08:00
endfunction
function! SpaceVim#layers#foo#config() abort
2017-03-02 22:20:46 +08:00
let g:foo_option1 = get(g:, 'foo_option1', 1)
let g:foo_option2 = get(g:, 'foo_option2', 2)
let g:foo_option3 = get(g:, 'foo_option3', 3)
" ...
2017-02-10 22:05:19 +08:00
endfunction
```
2018-01-03 23:14:15 +08:00
4. Add layer document `docs/layers/foo.md` for `foo` layer.
```md
---
title: "SpaceVim foo layer"
description: "This is a short discription for the foo layer"
---
# [SpaceVim Layers:](https://spacevim.org/layers) foo
<!-- vim-markdown-toc GFM -->
- [Description](#description)
- [Installation](#installation)
- [Layer](#layer)
- [Syntax checking && Code formatting](#syntax-checking--code-formatting)
- [Key bindings](#key-bindings)
- [Inferior REPL process](#inferior-repl-process)
- [RuboCop](#rubocop)
- [Running current script](#running-current-script)
<!-- vim-markdown-toc -->
## Description
This layer is for ruby development.
## Installation
### Layer
To use this configuration layer, add `call SpaceVim#layers#load('foo')` to your custom configuration file.
### Other dependences
## Key bindings
```
5. Open `docs/layers/index.md`, run `:call SpaceVim#dev#layers#update()` to update layer list.
2018-01-04 11:56:53 +08:00
6. send PR to SpaceVim.
2017-02-12 19:21:46 +08:00
2017-03-02 22:20:46 +08:00
##### Contributor to an existing layer
If you are contributing to an already existing layer, you should not modify any header file.
#### Contributing a keybinding
Mappings are an important part of SpaceVim.
First if you want to have some personal mappings, This can be done in your `~/.SpaceVim.d/init.vim` file.
If you think it worth contributing a new mappings then be sure to read the documentation to find the best mappings, then create a Pull-Request with your changes.
ALWAYS document your new mappings or mappings changes inside the relevant documentation file. It should be the the layer file and the [documentation.md](https://spacevim.org/documentation).
2018-01-02 20:00:16 +08:00
#### Language specified key bindings
All language specified key bindings are started with `SPC l` prefix.
we recommended to keep same language specified key bindings for different languages:
| Key Binding | Description |
| ----------- | ------------------------------------------------ |
| SPC l r | start a runner for current file |
2018-01-04 11:56:53 +08:00
| SPC l e | rename symbol |
| SPC l d | show doc |
2018-01-04 12:18:19 +08:00
| SPC l i r | remove unused imports |
| SPC l i s | sort imports with isort |
2018-01-02 20:00:16 +08:00
| SPC l s i | Start a language specified inferior REPL process |
| 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 |
2018-01-04 12:18:19 +08:00
All of these above key bindings are just recommended as default, but it also base on the language layer itself.
2017-03-02 22:20:46 +08:00
#### Contributing a banner
The startup banner is by default the SpaceVim logo but there are also ASCII banners available in the core/banner layer.
If you have some ASCII skills you can submit your artwork!
You are free to choose a reasonable height size but the width size should be around 75 characters.
2017-02-14 23:15:22 +08:00
## Build with SpaceVim
2017-02-16 23:23:12 +08:00
SpaceVim provide a lot of public [APIs](https://spacevim.org/apis), you can create plugins base on this APIs. also you can add a badge to the README.md of your plugin.
2017-02-14 23:15:22 +08:00
![](https://img.shields.io/badge/build%20with-SpaceVim-ff69b4.svg)
markdown
2017-02-15 23:56:04 +08:00
2017-02-14 23:15:22 +08:00
```md
2017-02-15 23:56:04 +08:00
[![](https://spacevim.org/img/build-with-SpaceVim.svg)](https://spacevim.org)
2017-02-14 23:15:22 +08:00
```
2017-02-12 19:21:46 +08:00
## Changelog
<ul>
2017-02-12 19:36:33 +08:00
{% for post in site.categories.changelog %}
2017-02-12 19:21:46 +08:00
<li>
<a href="{{ post.url }}">{{ post.title }}</a>
</li>
{% endfor %}
</ul>