Reading Why Git?
The nightmare of versioning
We all know what life without Git looks like:
- you work on a document
- then you make changes, but you are not sure whether those changes really are an improvement. So you decide to keep the first version, in case
- then you make new changes, so you save new files
If you are extremely organized, you made sure to name them with the date. Most people aren't extremely organized…
In no time, you have a folder full of versions of the same file and you may not even know which one is the current version. Some section may be better in one file (but you can't remember which), others in other files. It is a nightmare.
What you are doing, without realizing it, is a form of version control. This home-made and chaotic approach however is not really efficient. There are power tools which allow to do this much better. Git is one such tools.
Here comes Git
Git allows to save snapshots of a project at different points in time. Going back to our previous example, instead of having many files which correspond to alternative versions of the same document, you only have one file; but because its state was recorded each time you "took a snapshot", you can return the file to any of those states.
This has many advantages:
- each time you "take a snapshot", Git takes care of recording information such as date, etc. for you
- having only one file avoids the overwhelming feeling to open a directory full of alternative versions!
- Git comes with many tools which make it easy to compare one snapshot with another, to merge different snapshots together, to find snapshots, to navigate between one snapshot and another, to put changes aside for some time, etc.
Well, if one knows how to use it that is…
Branches
Branches provide an easy way to experiment with a project without risking to mess up the stable branch; or to have several developments happening in parallel.
Merging such explorations into the main branch or discarding them are equally easy.