GIT
By Colten Rouska
(Rizowski)
History
-
(2002) Linux kernel managed with BitKeeper
-
(2005) BitKeeper became unavailable and Git was born
About
Made For:
- Speed
- Simplicity
- Fully distributed
- Handle Large projects easily (Linux kernel)
- Non-linear development (thousands of parallel branches)
Inner Workings
Which is Git and which is like other version control systems?
Inner Workings
-
Git doesn't keep track of file changes over time.
-
Keeps a snapshot (mini file system) and stores a reference
Inner Workings
Do you require an internet connection to use Git?
No. To clone and push a repository you may need an internet connection.
Where is the Git history stored Server or Locally?
Git history is stored on every device that has the Git repository. (Locally)
Distributed Workflows
Git has a complex branching system. With it you can have multiple types of workflows.
Staging Area
The space between a modified file and a commit
Creating a Repository
Initializing (Fresh start)
root@Machine ~/myRepo
$ git init
Initialized empty Git repository in /home/myRepo/.git/
Cloning (Existing Repository)
root@Machine ~/myRepo
$ git clone myUsername@MyAwesomeRepo/myAwesomeProject.git
Modifications
Default:
root@Machine ~/myRepo
$ git status
# On branch master
#
# Initial commit
#
# Changes to be committed:
# (use "git rm --cached <file>..." to unstage)
#
# modified file: File1.txt
# new file: MyAwesomeFile.txt
Simplified:
$ git status -s
M File1.txt
A MyAwesomeFile.txt
Adding Files
Usage:
git add
usage: git add [options] [--] <file-pattern>
Options:
-n, --dry-run # run without executing and verbose results
-p, --patch # specify chunks of a file
-A, --all # add everything and skip stage
Wildcards:
Committing
Short hand:
root@Machine ~/myRepo
$ git commit -m "Some Message Here"
Long hand:
root@Machine ~/myRepo
$ git commit
< Type your message here >
# Please enter the commit message for your changes...
# Changes will be committed: ...
# ...
~
~
Patching Files
root@Machine ~/myRepo
$ git add -p
y - Yes add this hunk
n - No don't add this hunk
d - No don't add and skip remaining hunks
s - Split the hunk into smaller hunks
e - Manually edit the hunk
Ammending
Commit message
$ git commit --amend -m "My new message"
Insert forgotten files
$ git commit --amend -C HEAD
Branching
Create
$ git branch <Branch Name>
$ git checkout <Branch Name>
Create and Checkout
$ git checkout -b <Branch Name>
Push to Server
$ git push origin <Branch Name>
Push with hooks
$ git push -u <remote> <branch>
Rebasing
In what situation would you use these?
Rebasing from the remote repository:
Rebasing from master:
Bisect
$ git bisect start
$ git bisect bad
$ git bisect good [v1.0 ...]
$ git bisect reset
$ git bisect start HEAD v1.0
$ git bisect run bake # Hopefully the list is short
Tools
Merge Tools
Git logs / Commit history
Merging
A monster on its own
$ git merge
--commit / --no-commit / -m # commit the merge or not for inspection
--edit / -e # edit the auto generated merge message
--strategy / -s <something> # implement your own merging strategy
--abort # revert merge if conflicts arise
Git History
$ git log
commit c63h23354nfgj3945hrjfgj4hb43bh345
Author: Awesome Bub <Super@Duper.org>
Date: Thu Feb 30 08:14:55 2014 -0700
My Commit Message. #Bug-958
commit ...
Gitk
$ gitk --[all] &
--max-count=<number>
--since=<date>
--until=<date>
Generally Good Practices
- Branch Prune Repeat
- Major changes
- Features
- Experiments
- Be granular with commits
- Keep up to date with the project repository
- The left behind sheep gets eaten