Niweera
5/26/2019 - 11:20 AM

Keeping your fork synced with this repository

Keeping your fork synced with this repository

To keep your two repos up-to-date with my public repo, we first have to fetch and merge the public repo with your local machine's repo. Our second move will be to push your local repo to your GitHub fork. As you've seen earlier, it's only from your fork that you can ask for a "pull request". So your GitHub fork is the last repo to be updated.

Now, let's see how to do it:

First, you must be on your master branch. To know which branch you are on, check the first line of:

git status

if you are not already on master:

git checkout master 

Then you should add my public repo to your git with add upstream remote-url:

git remote add upstream https://github.com/Roshanjossey/first-contributions

This is a way of telling git that another version of this project exists in the specified url and we're calling it upstream. Once your git has a name let's fetch the latest version of the public repository:

git fetch upstream

You've just fetched the latest version of my fork (upstream remote). Now, you need to merge the public repository into your master branch.

git rebase upstream/master

Here you're merging the public repository with your master branch. Your local machine's master branch is now up-to-date. Lastly, if you push your master branch to your fork, your GitHub fork will also have the changes:

git push origin master

Notice here you're pushing to the remote named origin.

So by now or at this point, all your repositories are up-to-date. Well done! You should do this, everytime your GitHub repo tells you that you are a few commits behind.