Archive:Development/Tutorials/Git: Difference between revisions

From KDE TechBase
(moved final-words down and changed link names)
(big move of content into sub-pages)
Line 1: Line 1:
This tutorial will show you the basics for [http://git-scm.com/ Git]. For more information, please consult for example the official [http://www.kernel.org/pub/software/scm/git/docs/gittutorial.html tutorial introduction to Git] or this [http://cheat.errtheblog.com/s/git excellent cheat sheet].
This page is under construction today. Sorry for the inconvenience, it should be cleaner in a few hours (99% of the old content is [[/Basics here]] and [[/git-svn here]]). Want to help out? come to #sfsprint :)




== Setting up Git ==
short intro here: kde is trying out
[http://git-scm.com/ Git], many kde devs use it, here's some information, what might you want to read first, blah blah...


First, you should tell Git your name and email address. These information will be shown in the log and in commits. Also, you should allow color in Git. There are other color-related features, but this tutorial is just about basics.
Pages:
 
<pre>
git config --global user.name "Your Name"
git config --global user.email [email protected]
git config --global color.ui true
</pre>
 
In case you experience problems with colors you should test adding the following to your ~/.bashrc. The 'R' is the important part here.
 
<pre>
# R needed for git colours
export LESS="-RIM"
</pre>
 
 
== First steps with Git ==
 
We will start with a new Git repository and add one file to it.
 
<pre>
carsten@moinmoin:~/git> git init
Initialized empty Git repository in .git/
carsten@moinmoin:~/git> echo "Test content" > testfile
</pre>
 
Now we will check the status of the repository. Git will list one untracked file, that means the file has not yet been added to the repository.
 
<pre>
carsten@moinmoin:~/git> git status
# On branch master
#
# Initial commit
#
# Untracked files:
#  (use "git add <file>..." to include in what will be committed)
#
#      testfile
nothing added to commit but untracked files present (use "git add" to track)
</pre>
 
In the next three commands the file 'testfile' will be added and commited. Then  Git will check the status again.
 
<pre>
carsten@moinmoin:~/git> git add testfile
carsten@moinmoin:~/git> git commit -m "This is the first commit"
Created initial commit 246d7aa: This is the first commit
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 testfile
carsten@moinmoin:~/git> git status
# On branch master
nothing to commit (working directory clean)
</pre>
 
Ok, as you can see the file has been commited. Now let's see what we change the contents of the file:
 
<pre>
carsten@moinmoin:~/git> echo "new content" > testfile
carsten@moinmoin:~/git> git status
# On branch master
# Changed but not updated:
#  (use "git add <file>..." to update what will be committed)
#
#      modified:  testfile
#
no changes added to commit (use "git add" and/or "git commit -a")
carsten@moinmoin:~/git> git commit -a -m "Second commit"
Created commit 14a9802: Second commit
1 files changed, 1 insertions(+), 1 deletions(-)
</pre>
 
You see that Git noticed the changes in the file. <i>"git commit -a"</i> commits all changes in the repository. Note: This command does not add newly created files.
 
== Branches and merging are cheap in Git ==
 
<i>git branch</i> shows you the branches of the repository, the one with the '*' is the active one. So let us create a new branch called <i>"bugfix-branch"</i> and assume we want to fix a branch there. After this fix (in this case the new file) we will merge back all the hard work into the master branch.
 
<pre>
carsten@moinmoin:~/git> git branch
* master
carsten@moinmoin:~/git> git branch bugfix-branch
carsten@moinmoin:~/git> git checkout bugfix-branch
Switched to branch "bugfix-branch"
carsten@moinmoin:~/git> git branch
* bugfix-branch
  master
carsten@moinmoin:~/git> echo "a second file" > newfile
carsten@moinmoin:~/git> git commit -a
# On branch bugfix-branch
# Untracked files:
#  (use "git add <file>..." to include in what will be committed)
#
#      newfile
nothing added to commit but untracked files present (use "git add" to track)
carsten@moinmoin:~/git> git add newfile
carsten@moinmoin:~/git> git commit
Created commit 3264357: This file is here for a demonstration of Gits branch- and merge feature
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 newfile
</pre>
 
Ok, the bug is fixed now. Next step: Checkout the master branch and merge the two branches:
 
<pre>
carsten@moinmoin:~/git> git checkout master
Switched to branch "master"
carsten@moinmoin:~/git> ls
testfile
carsten@moinmoin:~/git> git merge bugfix-branch
Updating 14a9802..3264357
Fast forward
newfile |    1 +
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 newfile
carsten@moinmoin:~/git> ls
newfile  testfile
</pre>
 
If you would have edited "testfile" in the bugfix-branch, then git would automatically try to merge the contents of "testfile" in the bugfix-branch with the contents of "testfile" in the master branch. Sometimes this can cause a merge conflict. In that case you have to manually edit the "testfile" in the master branch, and afterwards you do a "git commit -a" to complete the merge. Git indicates the conflicting lines in the file itself.
 
 
== Lets now have a look at the log of the testfile ==
 
<pre>
carsten@moinmoin:~/git> git log testfile
commit 14a9802e249413003d1fa40002baa025aa54c75f
Author: Carsten Niehaus <[email protected]>
Date:  Fri Apr 18 18:07:18 2008 +0200
 
    Second commit
 
commit 246d7aad05139314e7ff62a5becb6c930f72fb8f
Author: Carsten Niehaus <[email protected]>
Date:  Fri Apr 18 18:06:33 2008 +0200
 
    This is the first commit
</pre>
 
 
 
 
== Handling local changes ==
 
git-svn cannot sync with SVN when you have local, uncommited changes. For that you are using <i>git stash</i>. That command move the local changes on a stack so that you can sync. After the sync you re-apply them to you Git tree and clear the stack. Very handy feature in many situations! Just do this:
 
<pre>
git stash
git svn rebase
git stash apply
git stash clear
</pre>
 
If you have local changes which you would like to revert use the following command. It will revert all local, uncommited changes.
 
<pre>
git checkout -f
</pre>
 
 
 
ignore everything below this line!
 
 
short intro here: kde is trying out git, many kde devs use it, here's some information, what might you want to read first, blah blah...
 
Pages to be created:
*[[/kde-qt|using kde-qt]]
*[[/kde-qt|using kde-qt]]
*[[/git-svn|using git-svn with kde]]
*[[/git-svn|using git-svn with kde]]
*[[/Basics|Basic git commands]]
*[[/KdeOnGit|accessing kde projects on git]]
*[[/KdeOnGit|accessing kde projects on git]]
*[[/Basics|basic git commands]]
*[[/BestPractices|things to avoid / best practices]]
*[[/BestPractices|things to avoid / best practices]]
*[[/Recipes|useful recipes]]
*[[/Recipes|useful recipes]]
Line 180: Line 16:


if you want to learn more about git, see the following resurces:
if you want to learn more about git, see the following resurces:
*[http://live.gnome.org/GitForGnomeDevelopers| git for gnome developers]
*[http://live.gnome.org/GitForGnomeDevelopers| git for gnome developers]
*[http://www.kernel.org/pub/software/scm/git/docs/gittutorial.html the official tutorial introduction to Git]
*[http://cheat.errtheblog.com/s/git git cheat sheet]

Revision as of 00:18, 2 November 2009

This page is under construction today. Sorry for the inconvenience, it should be cleaner in a few hours (99% of the old content is /Basics here and /git-svn here). Want to help out? come to #sfsprint :)


short intro here: kde is trying out Git, many kde devs use it, here's some information, what might you want to read first, blah blah...

Pages:

if you want to learn more about git, see the following resurces: