CONTRIBUTING.md 6.04 KB
Newer Older
Ben Straub committed
1 2 3 4 5
# Welcome to libgit2!

We're making it easy to do interesting things with git, and we'd love to have
your help.

6 7
## Licensing

8 9 10 11 12 13 14
By contributing to libgit2, you agree to release your contribution under
the terms of the license.  Except for the `examples` directory, all code
is released under the [GPL v2 with linking exception](COPYING).

The `examples` code is governed by the
[CC0 Public Domain Dedication](examples/COPYING), so that you may copy
from them into your own application.
15

Ben Straub committed
16 17
## Discussion & Chat

18 19 20
We hang out in the
[`#libgit2`](http://webchat.freenode.net/?channels=#libgit2)) channel on
irc.freenode.net.
Ben Straub committed
21

22 23 24 25 26
Also, feel free to open an
[Issue](https://github.com/libgit2/libgit2/issues/new) to start a discussion
about any concerns you have.  We like to use Issues for that so there is an
easily accessible permanent record of the conversation.

27 28 29 30
## Libgit2 Versions

The `master` branch is the main branch where development happens.
Releases are tagged
Russell Belfer committed
31
(e.g. [v0.21.0](https://github.com/libgit2/libgit2/releases/tag/v0.21.0) )
32 33 34
and when a critical bug fix needs to be backported, it will be done on a
`<tag>-maint` maintenance branch.

Ben Straub committed
35 36
## Reporting Bugs

37 38
First, know which version of libgit2 your problem is in and include it in
your bug report.  This can either be a tag (e.g.
39 40 41 42
[v0.17.0](https://github.com/libgit2/libgit2/releases/tag/v0.17.0)) or a
commit SHA
(e.g. [01be7863](https://github.com/libgit2/libgit2/commit/01be7863)).
Using [`git describe`](http://git-scm.com/docs/git-describe) is a
43
great way to tell us what version you're working with.
44

45
If you're not running against the latest `master` branch version,
46 47
please compile and test against that to avoid re-reporting an issue that's
already been fixed.
Ben Straub committed
48

49 50 51 52 53
It's *incredibly* helpful to be able to reproduce the problem.  Please
include a list of steps, a bit of code, and/or a zipped repository (if
possible).  Note that some of the libgit2 developers are employees of
GitHub, so if your repository is private, find us on IRC and we'll figure
out a way to help you.
Ben Straub committed
54 55 56

## Pull Requests

57 58 59
Our work flow is a [typical GitHub
flow](https://guides.github.com/introduction/flow/index.html), where
contributors fork the [libgit2 repository](https://github.com/libgit2/libgit2),
60
make their changes on branch, and submit a
61 62 63
[Pull Request](https://help.github.com/articles/using-pull-requests)
(a.k.a. "PR").  Pull requests should usually be targeted at the `master`
branch.
Ben Straub committed
64

65
Life will be a lot easier for you (and us) if you follow this pattern
66 67 68 69 70 71 72 73 74 75 76 77 78
(i.e. fork, named branch, submit PR).  If you use your fork's `master`
branch directly, things can get messy.

Please include a nice description of your changes when you submit your PR;
if we have to read the whole diff to figure out why you're contributing
in the first place, you're less likely to get feedback and have your change
merged in.

If you are starting to work on a particular area, feel free to submit a PR
that highlights your work in progress (and note in the PR title that it's
not ready to merge). These early PRs are welcome and will help in getting
visibility for your fix, allow others to comment early on the changes and
also let others know that you are currently working on something.
79

80
Before wrapping up a PR, you should be sure to:
Ben Straub committed
81

82
* Write tests to cover any functional changes
83 84
* Update documentation for any changed public APIs
* Add to the [`CHANGELOG.md`](CHANGELOG.md) file describing any major changes
85

86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
## Unit Tests

We believe that our unit tests allow us to keep the quality of libgit2
high: any new changes must not cause unit test failures, and new changes
should include unit tests that cover the bug fixes or new features.
For bug fixes, we prefer unit tests that illustrate the failure before
the change, but pass with your changes.

In addition to new tests, please ensure that your changes do not cause
any other test failures.  Running the entire test suite is helpful
before you submit a pull request.  When you build libgit2, the test
suite will also be built.  You can run all tests by simply running
the resultant `libgit2_clar` binary.  If you want to run a specific
unit test, you can name it with the `-s` option.  For example:

    libgit2_clar -sstatus::worktree::long_filenames

Or you can run an entire class of tests.  For example, to run all the
worktree status tests:

    libgit2_clar -sstatus::worktree

Ben Straub committed
108 109
## Porting Code From Other Open-Source Projects

110 111 112 113 114 115
`libgit2` is licensed under the terms of the GPL v2 with a linking
exception.  Any code brought in must be compatible with those terms.

The most common case is porting code from core Git.  Git is a pure GPL
project, which means that in order to port code to this project, we need the
explicit permission of the author.  Check the
Ben Straub committed
116
[`git.git-authors`](https://github.com/libgit2/libgit2/blob/development/git.git-authors)
117
file for authors who have already consented.
Ben Straub committed
118

119 120 121 122
Other licenses have other requirements; check the license of the library
you're porting code *from* to see what you need to do.  As a general rule,
MIT and BSD (3-clause) licenses are typically no problem.  Apache 2.0
license typically doesn't work due to GPL incompatibility.
Ben Straub committed
123

124 125 126 127
If your pull request uses code from core Git, another project, or code
from a forum / Stack Overflow, then *please* flag this in your PR and make
sure you've given proper credit to the original author in the code
snippet.
128

129
## Style Guide
Ben Straub committed
130

131 132
The public API of `libgit2` is [ANSI C](http://en.wikipedia.org/wiki/ANSI_C)
(a.k.a. C89) compatible.  Internally, `libgit2` is written using a portable
Russell Belfer committed
133
subset of C99 - in order to compile with GCC, Clang, MSVC, etc., we keep
134 135 136
local variable declarations at the tops of blocks only and avoid `//` style
comments.  Additionally, `libgit2` follows some extra conventions for
function and type naming, code formatting, and testing.
137 138 139

We like to keep the source code consistent and easy to read.  Maintaining
this takes some discipline, but it's been more than worth it.  Take a look
140 141
at the [conventions
file](https://github.com/libgit2/libgit2/blob/development/CONVENTIONS.md).
Ben Straub committed
142

143 144
## Starter Projects

145 146
See our [projects
list](https://github.com/libgit2/libgit2/blob/development/PROJECTS.md).