GIT & github
SHARE YOUR CODE
data:image/s3,"s3://crabby-images/2fbf7/2fbf7910986d5bcba7dbf72c3cb1e31da4bcf815" alt=""
data:image/s3,"s3://crabby-images/a7af9/a7af9689c08fc6fc2123ca8ad1037df5710b9ae5" alt=""
Why should I use version control?
Why should I use version control?
Have you ever:
- Made a change to code, realized it was a mistake and wanted to revert back?
- Lost code or had a backup that was too old?
- Had to maintain multiple versions of a product?
- Wanted to see the difference between two (or more) versions of your code?
- Wanted to prove that a particular change broke or fixed a piece of code?
Why should I use version control?
Have you ever:
- Wanted to review the history of some code?
- Wanted to submit a change to someone else's code?
- Wanted to share your code, or let other people work on your code?
- Wanted to see how much work is being done, and where, when and by whom?
- Wanted to experiment with a new feature without interfering with working code?
Why git?
- Speed
- Simple design
- Strong support for non-linear development (thousands of parallel branches)
- Fully distributed
- Able to handle large projects like the Linux kernel efficiently (speed and data size)
why github?
- It's widely in use
- Social networking functionality
- Pastebin-style site called Gist
- Is a community
- Octocat octodex.github.com
- github pages pages.github.com
data:image/s3,"s3://crabby-images/a7af9/a7af9689c08fc6fc2123ca8ad1037df5710b9ae5" alt=""
A social network for programmers :)
history of git
data:image/s3,"s3://crabby-images/6ea9c/6ea9c4d34170fa2e478a2de05cbc001451800aa3" alt=""
data:image/s3,"s3://crabby-images/e7939/e7939d813996c2153140a73c702a20b524cf98c5" alt=""
Git basics
Snapshots, Not Differences
data:image/s3,"s3://crabby-images/b0648/b06489bf519a23af09ff6ecbe96358a16392e44f" alt=""
data:image/s3,"s3://crabby-images/3fa61/3fa61e426d01ef82e6631d3853e1a4ef6aab0950" alt=""
git basics
Nearly Every Operation Is Local
You have the entire history of the project right there on your local disk
Git Has Integrity
Everything in Git is check-summed
Git Generally Only Adds Data
it is very difficult to lose data
git basics
The Three States
Getting Started
config git
git config {key} {value}
user.name
user.email
core.editor
merge.tool
git config --list
Getting Started
Help
git help <verb>
git help config
Auto-Completion
https://github.com/git/git/blob/master/contrib/completion/git-completion.bashsource ~/.git-completion.bash
Setting Up a Git Repository
$ git init
$ git init --bare <directory>
data:image/s3,"s3://crabby-images/51789/51789547cd9c3b165233c27a3360e41e3b00b1a7" alt=""
data:image/s3,"s3://crabby-images/56a3c/56a3c10a5b62d01b4c65f56d4ec727a406f916fe" alt=""
$ git clone git://github.com/schacon/simplegit-progit.git
data:image/s3,"s3://crabby-images/8f1f0/8f1f07a2972e793984c754a7277c11642c269111" alt=""
Setting Up a Git Repository
svn vs git
Setting Up a Git Repository
$ git add *.py
$ git add README
data:image/s3,"s3://crabby-images/504f7/504f7e83fa10e4669c9f745f9bc2cbfb6adc2c3a" alt=""
$ git commit -m 'initial project version'
data:image/s3,"s3://crabby-images/b6e5e/b6e5e2f2a8034a7a8cf6c08ac3f3b172f5af7486" alt=""
Setting Up a Git Repository
Setting Up a Git Repository
inspecting a git repository
$ git status
$ git log
inspecting a Git Repository
inspecting a Git Repository
$ git blame <file>
data:image/s3,"s3://crabby-images/bbab2/bbab23d4136333ef2f4b68f8d0282ed2b0cf7c6a" alt="http://www.linuxhispano.net/tira/blame.png"
other useful commands
$ cat .gitignore
$ git diff
$ git diff --staged
$ git rm <file>
$ git rm --cached <file>
$ git mv <file_from> <file_to>
Undoing Things
$ git commit --amend
$ git reset
$ git checkout <commit> <file>
$ git checkout <branch>
git revert <commit>
git clean
undoing things
reset vs revert
Don’t Reset Public History
Git Branches
data:image/s3,"s3://crabby-images/2a806/2a80645b7fc3905c821aef4448b18b0cccd936e4" alt="Git Tutorial: Branching and Merging"
git branches
$ git branch <branch>
data:image/s3,"s3://crabby-images/7acdd/7acdd4f6c3e3ed5b62ce4f4a8d6a56949f7be17f" alt="Git Tutorial: Create new branch"
data:image/s3,"s3://crabby-images/76fae/76faed4646dd5563a7627403e34201e8e8cdb899" alt="Git Tutorial: git branch"
git branches
$ git checkout <branch>
git branches
$ git merge
$ git merge --no-ff
fast-forward 3-way merge
fast-forward 3-way merge
data:image/s3,"s3://crabby-images/71c16/71c1634ea52175929c2863367b2dd994b4a640ba" alt="Git Tutorial: Three way merge"
Resolving Conflicts
data:image/s3,"s3://crabby-images/9d99e/9d99e272f772929e41612628c12cdeedb770804e" alt="http://www.linuxhispano.net/tira/conflictos.png"
$ git merge some_branch Auto-merging index.html CONFLICT (content): Merge conflict in index.html Automatic merge failed; fix conflicts and then commit the result.
Working with Remotes
$ git remote
$ git remote add test http://dev.example.com/test.git
$ git fetch <remote> <branch>
$ git branch -r
$ git merge origin/master
git pull <remote> <branch>
git push <remote> <branch>
Git Work-flows
getting stated with github
https://help.github.com/articles/set-up-git
useful links and references
https://www.atlassian.com/git/tutorial
http://zrusin.blogspot.com/2007/09/git-cheat-sheet.html
http://www.vogella.com/articles/Git/article.html
http://marklodato.github.io/visual-git-guide/index-en.html
Gracias
git & github
By Rafael Laverde
git & github
- 2,357