Moved Google Analytics code to makeover script
[gitmagic.git] / preface.txt
blob3d68172e05c97c3e9772d89a4447043613fcd605
1 = Git Magic =
2 Ben Lynn
3 August 2007
5 == Preface ==
7 http://git.or.cz/[Git] is a version control Swiss army knife. A reliable versatile multipurpose revision control tool whose extraordinary flexibility makes it tricky to learn, let alone master. I'm recording what I've figured out so far in these pages.
9 As Arthur C. Clarke observed, any sufficiently advanced technology is indistinguishable from magic, and this is a great way to approach Git. Newbies can ignore its inner workings and view Git as a gizmo that can amaze friends and infuriate enemies with its wondrous abilities.
11 So rather than go into details, I'll provide rough instructions for particular effects. After repeated use, gradually you will understand how each trick works, and how to tailor the recipes for your needs.
13 .About Git
15 - http://git.or.cz[Git homepage], which hosts
16  * http://www.kernel.org/pub/software/scm/git/docs/user-manual.html[The official Git user manual]
17  * http://www.kernel.org/pub/software/scm/git/docs/git.html[Git manual pages]
18  * http://www.kernel.org/pub/software/scm/git/docs/tutorial.html[Tutorial]
19  * http://git.or.cz/gitwiki/GitHistory[Historical background]
20 - http://en.wikipedia.org/wiki/Git_%28software%29[Wikipedia entry on Git].
21 - http://eagain.net/articles/git-for-computer-scientists/[Git For Computer Scientists] by Tommi Virtanen.
22 - http://www.selenic.com/mercurial/wiki/index.cgi/UnderstandingMercurial[Understanding Mercurial], a highly accessible introduction to distributed version control.
23 - http://lkml.org/lkml/2005/4/6/121[Linux Kernel Mailing List post] describing the chain of events that led to Git. The entire thread is a fascinating archaeological site for Git historians.
25 .Comparisons
27 - Git versus Subversion: articles by
28  * http://git.or.cz/gitwiki/GitSvnComparsion[Shawn Pearce]
29  * http://mjtsai.com/blog/2007/07/15/subversion-to-git/[Michael Tsai]
30  * http://utsl.gen.nz/talks/git-svn/intro.html[Sam Vilain]
31 - Git versus Mercurial: articles by
32  * http://tytso.livejournal.com/29467.html[Ted Tso]
33  * http://www.jukie.net/~bart/blog/git-vs-hg[Bart Trojanowski]
35 - http://subversion.tigris.org/subversion-linus.html[Subversion vs itself]: in response to its defence of Subversion's limitations, I claim Git is right for _every_ project. I also claim where there is more than one programmer, there is decentralized development.
37 Saying you should use systems that don't scale well when your project is tiny is like saying you should use Roman numerals for calculations involving small numbers.
39 .Other guides
41  - http://wiki.sourcemage.org/Git_Guide[Git Guide] at SourceMage.
42  - http://git.or.cz/course/svn.html[Git crash course for Subversion users]
43  - http://linux.yyz.us/git-howto.html[Kernel Hacker's Guide to Git] by Jeff Garzik.
44  - http://wiki.samba.org/index.php/Using_Git_for_Samba_Development[Using Git for Samba Development]
45  - http://polywww.in2p3.fr/~gaycken/Calice/Software/my_git_workflow.html[Advanced Git work flow] described by Götz Gaycken.
47 .Free Git hosting
49  - http://repo.or.cz/[http://repo.or.cz/] provides free Git hosting for free projects,
50 http://repo.or.cz/w/gitmagic.git[including this guide].