提交 a7fb11a8 编写于 作者: jia zhang's avatar jia zhang

Add contribution guidelines

Signed-off-by: jia zhang's avatarJia Zhang <zhang.jia@linux.alibaba.com>
上级 47591c65
# Contribution Guidelines
Contributions should be made via pull requests. Pull requests will be reviewed by one or more maintainers and merged when acceptable.
## Commit message
### Format
The commit messages should answer two questions: what changed and why this change was made. The subject line should feature the what and the commit body should describe the why, e.g:
```
rune/libenclave: work around nanosleep() issue
nanosleep() may return the remaining duration longer than
requested one due to timer slack.
```
The format can be described more formally:
```
<subsystem>: <what changed>
<BLANK LINE>
<why this change was made>
<BLANK LINE>
<SOB LINE>
```
The first line is the subject and should be no longer than 50 characters, the other lines should be wrapped at 72 characters (see [this blog post](https://preslav.me/2015/02/21/what-s-with-the-50-72-rule/) for why).
If the change affects more than one subsystem, you can use comma to separate them like `rune/libenclave,shim:`.
The first letter of <what changed> is lowercase, without ending with a full stop.
If the change affects many subsystems, you can use ```*``` instead, like ```*:```
The message of commit body should describe why the change was made and how the code works at the high level.
### Sign your work
A DCO sign-off is a line placed at the end of a commit message containing a contributor's signature.
In adding this, the contributor certifies that they have the right to contribute the material.
Here are the steps to sign one's work:
Once the contributor certifies the DCO below (from [developercertificate.org](https://developercertificate.org/)):
```
Developer Certificate of Origin
Version 1.1
Copyright (C) 2004, 2006 The Linux Foundation and its contributors.
1 Letterman Drive
Suite D4700
San Francisco, CA, 94129
Everyone is permitted to copy and distribute verbatim copies of this
license document, but changing it is not allowed.
Developer's Certificate of Origin 1.1
By making a contribution to this project, I certify that:
(a) The contribution was created in whole or in part by me and I
have the right to submit it under the open source license
indicated in the file; or
(b) The contribution is based upon previous work that, to the best
of my knowledge, is covered under an appropriate open source
license and I have the right under that license to submit that
work with modifications, whether created in whole or in part
by me, under the same open source license (unless I am
permitted to submit under a different license), as indicated
in the file; or
(c) The contribution was provided directly to me by some other
person who certified (a), (b) or (c) and I have not modified
it.
(d) I understand and agree that this project and the contribution
are public and that a record of the contribution (including all
personal information I submit with it, including my sign-off) is
maintained indefinitely and may be redistributed consistent with
this project or the open source license(s) involved.
```
The contributor then just needs to add a line to every git commit message:
Signed-off-by: Joe Smith <joe.smith@example.com>
One's real name must be used (no pseudonyms or anonymous contributions).
The easiest way to do this is, assuming `user.name` and `user.email` are set via
the git cli configuration (`git config`), is to sign commits automatically via `git commit -s`.
Finally, the `git log` information for a commit should show something like this:
```
Author: Joe Smith <joe.smith@example.com>
Date: Thu Feb 2 11:41:15 2018 -0800
Update README
Signed-off-by: Joe Smith <joe.smith@example.com>
```
Notice the `Author` and `Signed-off-by` lines match. If they don't,
the PR will be rejected by the automated DCO check.
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册