Annex Contributing to someone else's project
There are countless free and open source tools on GitHub. If you use one such tool and find a problem, or think that you can improve the project, or if you would like to request a novel feature, how can you go about it?
To do before doing anything else
There are a few rules to follow before starting to contribute to someone else's project:
- Make sure that you have the latest version of the project (your issue/suggestion may have already been addressed in a recent version)
- Some projects have guidelines as to how to contribute, so make sure to read them
- Make sure that there isn't already an open issue on what you want to contribute
Opening issues
The easiest thing to do if you find a bug or want to make a feature request is to open an issue:
Go to the GitHub webpage of the project, select the Issues tab, then click on New issue .
Submitting a pull request
Now, a more advanced approach is to actually suggest changes to the code of the project.
If you want to develop your own version of the project, you can fork the project and keep it at that. You have all privileges on the forked project. So you can make any change you want there. You can clone it to your machine and develop the fork however you want. But your fork does not get updated to the improvements made to the initial project. It is an independent project of its own.
If you want to keep your fork up to date with the initial project, you need to:
- Clone your fork on your machine (this will automatically set your fork on GitHub as a remote called origin )
- Add a second remote, this one pointing to the initial project. Usually, that one is called upstream
- Pull from upstream
From there on, you can pull from upstream (the initial project) and push/pull to/from origin (your fork).
Of course, if your project and the initial one diverge in places, this will lead to conflicts that you will have to resolve as you merge the pulls from upstream .
Most of the time however, you don't want to develop your own version of a project. Instead, you want to make it better by contributing to it. But you can't push changes to upstream directly since you are not part of that project. You don't have write access to that repository. If anybody could push to any project, that would be utter chaos.
So how do you contribute code to someone else's project?
Here is the proper workflow, as described on many websites and in the Git manual to submit a pull request (PR):
- Fork the project
- Clone your fork to your machine
- Add the original fork as a remote called upstream
- If you forked your project a while ago, pull from upstream to make sure that your contributions are made on an up to date version of the project
- Create a branch on your cloned local project and make your changes in that branch
- Push that branch to your fork (that means to origin , not to upstream : you aren't allowed to push to upstream since it is not your project)
- Go to the original project GitHub's page and open a pull request from your fork (as soon as you have pushed your branch to origin , GitHub will automatically offer you to do so)
This is typically followed by some conversation on the pull request page between the project developer/maintainer and you. They may ask you to make some adjustments, so you may have to commit and push several changes to that branch. Once/if they are happy with your suggestion, they will merge your PR into their project. You can then delete the branch in which you developed those changes.