Skip to content

Latest commit

 

History

History
107 lines (71 loc) · 4.27 KB

CONTRIBUTING.md

File metadata and controls

107 lines (71 loc) · 4.27 KB

Contributing to PipeRider

Issues and PRs are welcome!

Developer Certificate of Origin

PipeRider DCO and signed-off-by process

The PipeRider project use the signed-off-by language and process used by the Linux kernel, to give us a clear chain of trust for every patch received.

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.

Using the Signed-Off-By Process

We have the same requirements for using the signed-off-by process as the Linux kernel. In short, you need to include a signed-off-by tag in every patch:

This is my commit message

Signed-off-by: Random J Developer <random@developer.example.org>

Git even has a -s command line option to append this automatically to your commit message:

$ git commit -s -m 'This is my commit message'

Write Commit message properly

Structure your commit message like this:

From: https://git-scm.com/book/ch5-2.html

Short (50 chars or less) summary of changes

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.

Further paragraphs come after blank lines.

  • Bullet points are okay, too

  • Typically a hyphen or asterisk is used for the bullet, preceded by a single space, with blank lines in between, but conventions vary here

DO

  • Write the summary line and description of what you have done in the imperative mood, that is as if you were commanding someone. Start the line with "Fix", "Add", "Change" instead of "Fixed", "Added", "Changed".
  • Always leave the second line blank.
  • Line break the commit message (to make the commit message readable without having to scroll horizontally in gitk).
  • The summary should be meaningful and descriptive.

DON'T

  • Don't end the summary line with a period - it's a title and titles don't end with a period.
  • Avoid mentioning specific deployments or customers. Instead, describe what problem is solved.

Tips

  • If it seems difficult to summarize what your commit does, it may be due to multiple logical changes or bug fixes, that are better split up into several commits using git add -p.

Recommendations

  • Use company email to commit. You can set in the project scope by invoking git config user.email dev@infuseai.io inside the repository.
  • Sign-off your commits. [Ref]
  • Add Co-authored-by if you're pairing with someone. [Ref]

Examples

❌ Bad

Fix bugs
  • it should have a reason or cause to be fixed.
  • please write the DCO (git commit -s)

✅ Good

[Feature] sc-25903 introduce init and debug commands

Signed-off-by: Kent Huang <kentwelcome@gmail.com>
Co-authored-by: Ching-Yi Chan  <qrtt1@infuseai.io>
Co-authored-by: Timothy Lee <ctiml@infuseai.io>
  • there is a purpose to add this commit
    • feature added: two commands were introduced
  • write the DCO