mirror of
https://github.com/neovim/neovim.git
synced 2025-01-01 17:23:36 -07:00
b3b25c2490
Single point of truth (SPOT): Do not sprinkle "contributing" guidelines across various resources; CONTRIBUTING.md is the authority. DRY: Do not repeat guidelines in CONTRIBUTING.md which are covered by ISSUE_TEMPLATE.md
125 lines
5.6 KiB
Markdown
125 lines
5.6 KiB
Markdown
# Contributing to Neovim
|
|
|
|
## Getting started
|
|
|
|
- Help us review [open pull requests](https://github.com/neovim/neovim/pulls)!
|
|
See [Reviewing](#reviewing) for guidelines.
|
|
- Try an [entry-level issue][entry-level] if you are wondering where to start.
|
|
- Or [merge a Vim patch].
|
|
|
|
## Reporting problems
|
|
|
|
- Check the [**FAQ**][wiki-faq].
|
|
- Search [existing issues][github-issues] (including closed!)
|
|
- Update Neovim to the latest version to see if your problem persists.
|
|
- If you're using a plugin manager, comment out your plugins, then add them back
|
|
in one by one, to narrow down the cause of the issue.
|
|
- Crash reports which include a stacktrace are 10x more valuable.
|
|
- [Bisecting][git-bisect] to the cause of a regression often leads to an
|
|
immediate fix.
|
|
|
|
## Pull requests ("PRs")
|
|
|
|
- To avoid duplicate work, you may want to create a `[WIP]` pull request so that
|
|
others know what you are working on.
|
|
- Avoid cosmetic changes to unrelated files in the same commit: extra noise
|
|
makes reviews more difficult.
|
|
- Use a [feature branch][git-feature-branch] instead of the master branch.
|
|
- [Rebase your feature branch][git-rebasing] onto (upstream) master before
|
|
opening the PR.
|
|
- After addressing the review comments, it's fine to rebase and force-push to
|
|
your review.
|
|
- Try to [tidy your history][git-history-rewriting]: combine related commits
|
|
with interactive rebasing, separate monolithic commits, etc.
|
|
|
|
### Stages: WIP, RFC
|
|
|
|
Pull requests are processed in two stages: _WIP_ (Work In Progress) and _RFC_
|
|
(Request For Comment).
|
|
|
|
- Untagged PRs are assumed to be RFC, meaning the work is ready for review and
|
|
you would like feedback.
|
|
- Preprend `[WIP]` to the PR title if you are _not_ ready for feedback and the
|
|
work is still in flux. This saves time and confusion.
|
|
|
|
### Commit messages
|
|
|
|
Follow [commit message hygiene][hygiene] to *make reviews easier* and to make
|
|
the VCS/git logs more valuable.
|
|
|
|
- Try to keep the first line under 72 characters.
|
|
- **Prefix the commit subject with a _scope_:** `doc:`, `test:`, `foo.c:`,
|
|
`runtime:`, ...
|
|
- For commits that contain only style/lint changes, a single-word subject
|
|
line is preferred: `style` or `lint`.
|
|
- A blank line must separate the subject from the description.
|
|
- Use the _imperative voice_: "Fix bug" rather than "Fixed bug" or "Fixes bug."
|
|
|
|
### Automated builds (CI)
|
|
|
|
Each pull request must pass the automated builds ([travis CI] and [quickbuild]).
|
|
|
|
- CI builds are compiled with [`-Werror`][gcc-warnings], so if your PR
|
|
introduces any compiler warnings, the build will fail.
|
|
- If any tests fail, the build will fail.
|
|
See [Building Neovim#running-tests][wiki-run-tests] to run tests locally.
|
|
Passing locally doesn't guarantee passing the CI build, because of the
|
|
different compilers and platforms tested against.
|
|
- CI runs [ASan] and other analyzers. To run valgrind locally:
|
|
`VALGRIND=1 make test`
|
|
- The `lint` build ([#3174][3174]) checks modified lines _and their immediate
|
|
neighbors_. This is to encourage incrementally updating the legacy style to
|
|
meet our style guidelines.
|
|
- A single word (`lint` or `style`) is sufficient as the subject line of
|
|
a commit that contains only style changes.
|
|
- [How to investigate QuickBuild failures](https://github.com/neovim/neovim/pull/4718#issuecomment-217631350)
|
|
|
|
### Coverity
|
|
|
|
[Coverity](https://scan.coverity.com/projects/neovim-neovim) runs against the
|
|
master build. If you want to view the defects, just request access at the
|
|
_Contributor_ level. An Admin will grant you permission.
|
|
|
|
Use this commit-message format for coverity fixes:
|
|
|
|
coverity/<id>: <description of what fixed the defect>
|
|
|
|
where `<id>` is the Coverity ID (CID). For example see [#804](https://github.com/neovim/neovim/pull/804).
|
|
|
|
## Reviewing
|
|
|
|
To help review pull requests, start with [this checklist][review-checklist].
|
|
|
|
Reviewing can be done on GitHub, but you may find it easier to do locally.
|
|
Using [`hub`][hub], you can create a new branch with the contents of a pull
|
|
request, e.g. [#1820][1820]:
|
|
|
|
hub checkout https://github.com/neovim/neovim/pull/1820
|
|
|
|
Use [`git log -p master..FETCH_HEAD`][git-history-filtering] to list all
|
|
commits in the feature branch which aren't in the `master` branch; `-p`
|
|
shows each commit's diff. To show the whole surrounding function of a change
|
|
as context, use the `-W` argument as well.
|
|
|
|
|
|
[entry-level]: https://github.com/neovim/neovim/issues?labels=entry-level&state=open
|
|
[gcc-warnings]: https://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html
|
|
[git-bisect]: http://git-scm.com/book/tr/v2/Git-Tools-Debugging-with-Git
|
|
[git-feature-branch]: https://www.atlassian.com/git/tutorials/comparing-workflows
|
|
[git-history-filtering]: https://www.atlassian.com/git/tutorials/git-log/filtering-the-commit-history
|
|
[git-history-rewriting]: http://git-scm.com/book/en/v2/Git-Tools-Rewriting-History
|
|
[git-rebasing]: http://git-scm.com/book/en/v2/Git-Branching-Rebasing
|
|
[github-issues]: https://github.com/neovim/neovim/issues
|
|
[1820]: https://github.com/neovim/neovim/pull/1820
|
|
[hub]: https://hub.github.com/
|
|
[hygiene]: http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html
|
|
[style-guide]: http://neovim.io/develop/style-guide.xml
|
|
[ASan]: http://clang.llvm.org/docs/AddressSanitizer.html
|
|
[wiki-run-tests]: https://github.com/neovim/neovim/wiki/Building-Neovim#running-tests
|
|
[wiki-faq]: https://github.com/neovim/neovim/wiki/FAQ
|
|
[review-checklist]: https://github.com/neovim/neovim/wiki/Code-review-checklist
|
|
[3174]: https://github.com/neovim/neovim/issues/3174
|
|
[travis CI]: https://travis-ci.org/neovim/neovim
|
|
[quickbuild]: http://neovim-qb.szakmeister.net/dashboard
|
|
[merge a Vim patch]: https://github.com/neovim/neovim/wiki/Merging-patches-from-upstream-Vim
|