Developing FreeCAD with GitKraken: Difference between revisions

From FreeCAD Documentation
m (added more refinements and external links)
(No difference)

Revision as of 11:06, 30 July 2017

Please Read

This guide is not written to teach users how to use git in it's totality, far from it. git is super handy tool with a lot of functionality that goes way beyond the scope of this intro. This is just a cursory introduction highlighting on how to work with git in a GUI environment. It also serves as a means to enourage FreeCAD users to contribute to FreeCAD. This tutorial uses GitKraken, proprietary software that is free to use for non-commercial use.


Setup git Development

  1. Download GitKraken (There are different ways to download GitKraken depending on your OS. I use an Arch Linux based distro called Manjaro and added it through my package manager)
  2. In your web browser go to: https://github.com/FreeCAD/FreeCAD
  3. Click the Fork button. This will clone the FreeCAD/FreeCAD repo to your own account. In other words the URL to access your fork of FreeCAD is:
    https://github.com/GITUBUSERNAME/FreeCAD.git
  4. Open GitKraken and go to File > Clone Repo
  5. GitKraken will now git clone your repository
    • Now an important point: Please read the different between origin vs. upstream remote repos. Essentially your fork of FreeCAD is the origin repo. The official FreeCAD git repo FreeCAD/FreeCAD is your upstream. You now need to set the upstream repo as FreeCAD.
  6. Go to File > Open Terminal
  7. Enter the following to set up your upstream remote repo
    git remote add upstream https://github.com/YOURGITUHUBUSERNAME/FreeCAD.git
  8. Now check what remote branches you have set by typing:
    git remote -v
  9. You should see something like this in the terminal:
    origin	https://github.com/foobar/FreeCAD (fetch)
    origin	https://github.com/foobar/FreeCAD (push)
    upstream	https://github.com/FreeCAD/FreeCAD.git (fetch)
    upstream	https://github.com/FreeCAD/FreeCAD.git (push)
  10. Switch back to GitKraken interface.
  11. On the left side of the screen you will see a sidebar with a section labled Local double click on the master branch (this will make sure you're on the master branch AKA
    git checkout master
  12. Click on the Push] icon on the top right side of the interface. This will push your Local master to your Remote origin master

Deciphering the GitKraken Interface

For more in-depth understanding of the GitKraken interface checkout the Getting Started Guide.

  • Orientation:
    • Local = local machine
      • Local master = your local copy FreeCAD <= symbolized as Blue in Screenshot)
    • Remote = Remote GitHub repos
      • Remote Upstream = Official FreeCAD repo (AKA FreeCAD/FreeCAD) <= Symbolized as Green in Screenshot
      • Remote Origin = Fork of FreeCAD/FreeCAD (should look something like: github.com/YourGitHubUsername/FreeCAD) <= Symbolized as Red in Screenshot

Notice

That both remote origin master and local master are a few commits behind upstream in the above screenshot. You can remedy this by Rebasing


Rebasing

  • Checkout the Local Master branch by double clicking on it (this is the equivalent of typing git branch master in the terminal)
  • Move the mouse to the where latest Upstream commit is, right click mouse and choose Rebase master on upstream/master (this will pull down the Upstream changes in to your Local master)
  • Move the mouse and press the Push button. GitKraken (This pushes from your 'Local master' to 'Remote Origin master')

Now all your repos are in sync!


Branches

Squashing Commits

Squashing is when you have several commits you want to condense down in to one commit. From the GitKraken manual: Squashing is available for commits that meet the following requirements:

   Selection contains more than one commit
   The youngest commit (by commit date) is also the current HEAD commit
   Genealogically consecutive
   Chronologically consecutive
   The oldest commit in the list has a parent

If all these conditions are met, the Squash option appears when you right click the commit node. See screencast at: https://support.gitkraken.com/img/documentation/working-with-files/commits/squash.gif