This post gives you the commands you will need to keep your fork up to date with the master repository in GitHub.

Confession

I once confessed on Twitter that I used to delete my fork in GitHub, re-fork it and download it all again. That was my way to keep it up to date.

If you follow the steps below, or watch the video, you will see how easy it is to keep your fork up to date. In the example below and in the video I am keeping my fork of UmbracoCms up to date with the v7 branch.

Let's do this

First of all you will need to fork the project in GitHub if you haven't done that already. Make sure you have downloaded your fork to your local file system.

Make sure you are on your master branch and you don't have anything to commit.

If you are doing this for the first time, you need to make sure you add the upstream repository, you will only need to do this once, so if you come back to this post later you should be able to skip this step.

git remote add upstream https://github.com/umbraco/Umbraco-CMS.git

Now you can fetch the latest from the upstream repository

git fetch upstream

Next you can do a rebase to bring your fork up to date with the changes in the upstream repository

git rebase v8/contrib

Now we have done this we need to push the changes to our git repository

git push

We can now check the status to see if we are up to date. And if we go to our fork on GitHub it should say it is up to date with master.

git status

We are now free to create a new branch for an issue we want to work on. You can just create a branch using git like this:

git checkout -b feature/my-cool-feature

If you would like to come back to this post again later, you can either bookmark this page, or just go to codeshare.co.uk/fork for quickness.

Here is the video in case you want to watch me show you instead:

Watch on YouTube

Paul Seal

Umbraco MVP and .NET Web Developer from Derby (UK) who specialises in building Content Management System (CMS) websites using MVC with Umbraco as a framework. Paul is passionate about web development and programming as a whole. Apart from when he's with his wife and son, if he's not writing code, he's thinking about it or listening to a podcast about it.

Proudly sponsored by

Moriyama

  • Moriyama build, support and deploy Umbraco, Azure and ASP.NET websites and applications.
AppVeyor

  • CI/CD service for Windows, Linux and macOS
  • Build, test, deploy your apps faster, on any platform.
elmah.io

  • elmah.io is the easy error logging and uptime monitoring service for .NET.
  • Take back control of your errors with support for all .NET web and logging frameworks.
uSync Complete

  • uSync.Complete gives you all the uSync packages, allowing you to completely control how your Umbraco settings, content and media is stored, transferred and managed across all your Umbraco Installations.
uSkinned

  • More than a theme for Umbraco CMS, take full control of your content and design with a feature-rich, award-nominated & content editor focused website platform.
UmbHost

  • Affordable, Geo-Redundant, Umbraco hosting which gives back to the community by sponsoring an Umbraco Open Source Developer with each hosting package sold.