85 lines
2.9 KiB
Markdown
85 lines
2.9 KiB
Markdown
|
Contributing to Bitcore
|
||
|
=======
|
||
|
|
||
|
Are you a developer looking to learn more about bitcoin?
|
||
|
Bitcore is a great opportunity to do so, and give back to
|
||
|
the community. At BitPay we encourage any developer to read the source
|
||
|
code and help us improve it by fixing bugs, implementing
|
||
|
new exciting features, and testing existing code.
|
||
|
|
||
|
Pull requests are the standard mechanism by which you contribute code to open-source projects.
|
||
|
To do so, start by forking our repo on GitHub. Go to
|
||
|
[github.com/bitpay/bitcore](https://github.com/bitpay/bitcore)
|
||
|
and click the 'Fork' button. You'll get your own fork of the repository which will look something like this:
|
||
|
```
|
||
|
https://github.com/user/bitcore
|
||
|
```
|
||
|
|
||
|
Then clone your fork on your machine:
|
||
|
```
|
||
|
git clone git@github.com:user/bitcore && cd bitcore/
|
||
|
```
|
||
|
|
||
|
Add the official repo as a remote, to track our changes:
|
||
|
```
|
||
|
git remote add bitpay git@github.com:bitpay/bitcore.git
|
||
|
```
|
||
|
|
||
|
Create a new branch for the changes you are going to contribute, with a relevant name. Some examples:
|
||
|
```
|
||
|
git checkout -b test/some-module
|
||
|
git checkout -b feature/some-new-stuff
|
||
|
git checkout -b fix/some-bug
|
||
|
git checkout -b remove/some-file
|
||
|
```
|
||
|
|
||
|
Work on your changes:
|
||
|
```
|
||
|
vim somefile.txt
|
||
|
git add somefile.txt
|
||
|
git commit -a -m"adding somefile.txt"
|
||
|
```
|
||
|
|
||
|
When you think your code is ready, update your branch by
|
||
|
getting the changes from the main repo first, as there may have been
|
||
|
changes while you were working:
|
||
|
```
|
||
|
git pull --rebase bitpay master
|
||
|
```
|
||
|
(You may need to solve any conflicts from the rebase at this point.)
|
||
|
|
||
|
Note that we require rebasing your branch instead of mergeing it, for commit readability reasons.
|
||
|
|
||
|
A final and important step is to run the tests and check they all pass.
|
||
|
This is done by running `mocha` in the project's directory. You'll also
|
||
|
need to check that tests pass in the browser, by running:
|
||
|
`grunt shell` and opening the `bitcore/test/index.html` file in your
|
||
|
browser.
|
||
|
|
||
|
After that, you can push the changes to your fork, by doing:
|
||
|
```
|
||
|
git push origin your_branch_name
|
||
|
git push origin feature/some-new-stuff
|
||
|
git push origin fix/some-bug
|
||
|
```
|
||
|
|
||
|
Finally go to [github.com/bitpay/bitcore](https://github.com/bitpay/bitcore) in your
|
||
|
web browser and issue a new pull request. GitHub normally recognizes you have pending
|
||
|
changes in a new branch and will suggest creating the pull request. If it doesn't, you can
|
||
|
always go to [github.com/bitpay/bitcore/compare](https://github.com/bitpay/bitcore/compare) and
|
||
|
choose the correct forks and branches.
|
||
|
|
||
|
Main contributors will review your code and possibly ask for
|
||
|
changes before your code is pulled in to the main repository.
|
||
|
We'll check that all tests pass, review the coding style, and
|
||
|
check for general code correctness. If everything is OK, we'll
|
||
|
merge your pull request and your code will be part of bitcore.
|
||
|
|
||
|
If you have any questions feel free to post them to
|
||
|
[github.com/bitpay/bitcore/issues](https://github.com/bitpay/bitcore/issues).
|
||
|
|
||
|
Thanks for your time and code!
|
||
|
|
||
|
|
||
|
|