CONTRIBUTING.md 3.7 KB
Newer Older
jia zhang's avatar
jia zhang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
# 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.