A contribution may be related to bug fixing, feature enhancement, or application addition.
Please make sure to create a new issue (double-check if your issue has not been discussed already) on issues tracker first.
Then, follow the steps below. All issues related to improving Husky are very much appreciated, and could be discussed with the Husky Team.
- Fork Husky as your own repository.
- Clone your own Husky to local:
$ git clone YOUR/Husky.git
- Add upstream remote to your local repository:
$ git remote add upstream https://github.com/husky-team/husky.git
- Fetch upstream:
$ git fetch upstream
-
Sync to upstream:
$ git checkout master && git rebase upstream/master
-
Create your developing branch:
$ git checkout -b dev
-
Make your changes and commit them:
$ git add FILES && git commit -m "MESSAGE"
-
Follow this format for the commit message:
[PART] (1) Commit summary(2)
Issues(3)
Detailed description(4) -
Before committing, it would be better to pass
lint.py
andcheck-clang-format.sh
:$ cd husky && ./script/lint.py DIRECTORY && HUSKY_ROOT=. ./script/check-clang-format.sh
-
Push local commit to your own repository:
$ git push -u/f origin dev
-
Create a pull request to the upstream repository. You can also add reviewers. It'd be better for each commit to have only a single PR.
More about the commit message:
(1) [PART] shows what section of Husky your patch is addressed to. If the patch is addressed to a very specific subsection, this can be represented as [Part][SubPart].
(2) Commit summary needs to tell WHAT IS BEING DONE. DON'T overextend it. Capitalize the first letter. It is not necessary to add a period.
(3) If there are any issues on the issue tracker that are being dealt with by this patch, they can be listed here.
(4) Add necessary descriptions about this patch such as usages, plans or technologies. Use punctuation.
For example:
[Build][InputFormat] Fixed error for xxx not found
issue #xx
Should add macros before including xxx.