2010-06-03 14:34:35 +02:00
|
|
|
---
|
|
|
|
layout: reference
|
|
|
|
---
|
|
|
|
<div class="box">
|
|
|
|
<h2>Introduction to the Git Reference</h2>
|
|
|
|
<div class="block">
|
|
|
|
<p>
|
|
|
|
This is the Git reference site. This is meant to be a quick
|
|
|
|
reference for learning and remembering the most important and
|
|
|
|
commonly used Git commands. The commands are organized into
|
|
|
|
sections of the type of operation you may be trying to do, and
|
2010-10-15 15:11:32 -04:00
|
|
|
will present the common options and commands needed to accomplish
|
2010-06-03 14:34:35 +02:00
|
|
|
these common tasks.
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Each section will link to the next section, so it can be used
|
2010-06-03 20:13:39 +02:00
|
|
|
as a tutorial. Every page will also link to more in-depth
|
2011-12-14 15:30:05 -05:00
|
|
|
Git documentation such as the official manual pages and relevant
|
2012-12-03 22:56:49 -05:00
|
|
|
sections in the <a href="http://git-scm.com/book">Pro Git book</a>,
|
|
|
|
so you can learn more about any of
|
|
|
|
the commands. First, we'll start with thinking about source code
|
2010-06-03 20:13:39 +02:00
|
|
|
management like Git does.
|
2010-06-03 14:34:35 +02:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="box">
|
|
|
|
<h2>How to Think Like Git</h2>
|
|
|
|
<div class="block">
|
|
|
|
<p>
|
2012-01-16 13:41:14 +02:00
|
|
|
The first thing that is important to understand about Git is
|
2012-12-03 22:56:49 -05:00
|
|
|
that it thinks about version control very differently than
|
2010-06-03 14:34:35 +02:00
|
|
|
Subversion or Perforce or whatever SCM you may be used to. It
|
|
|
|
is often easier to learn Git by trying to forget your assumptions
|
|
|
|
about how version control works and try to think about it in the
|
|
|
|
Git way.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
2012-12-03 22:56:49 -05:00
|
|
|
Let's start from scratch. Assume you are designing a new source
|
2010-08-11 13:47:38 +00:00
|
|
|
code management system. How did you do basic version control before
|
2012-12-03 22:56:49 -05:00
|
|
|
you used a tool for it? Chances are that you simply copied your
|
2010-06-03 14:34:35 +02:00
|
|
|
project directory to save what it looked like at that point.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre> $ cp -R project project.bak </pre>
|
|
|
|
|
|
|
|
<p>
|
2012-12-03 22:56:49 -05:00
|
|
|
That way, you can easily revert files that get messed up later, or
|
2010-06-03 14:34:35 +02:00
|
|
|
see what you have changed by comparing what the project looks like
|
|
|
|
now to what it looked like when you copied it.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
If you are really paranoid, you may do this often, maybe putting the
|
|
|
|
date in the name of the backup:
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre> $ cp -R project project.2010-06-01.bak </pre>
|
|
|
|
|
|
|
|
<p>
|
2012-12-03 22:56:49 -05:00
|
|
|
In that case, you may have a bunch of snapshots of your project that
|
|
|
|
you can compare and inspect from. You can even use this model to
|
2010-06-03 14:34:35 +02:00
|
|
|
fairly effectively share changes with someone. If you zip up your
|
|
|
|
project at a known state and put it on your website, other developers
|
|
|
|
can download that, change it and send you a patch pretty easily.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
$ wget http://sample.com/project.2010-06-01.zip
|
|
|
|
$ unzip project.2010-06-01.zip
|
|
|
|
$ cp -R project.2010-06-01 project-my-copy
|
|
|
|
$ cd project-my-copy
|
|
|
|
$ (change something)
|
|
|
|
$ diff project-my-copy project.2010-06-01 > change.patch
|
|
|
|
$ (email change.patch)</pre>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Now the original developer can apply that patch to their copy of the
|
2012-12-03 22:56:49 -05:00
|
|
|
project and they have your changes. This is how many open source
|
2010-06-03 14:34:35 +02:00
|
|
|
projects have been collaborated on for several years.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
This actually works fairly well, so let's say we want to write a tool
|
|
|
|
to make this basic process faster and easier. Instead of writing a tool
|
|
|
|
that versions each file individually, like Subversion, we would probably
|
|
|
|
write one that makes it easier to store snapshots of our project without
|
|
|
|
having to copy the whole directory each time.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
This is essentially what Git is. You tell Git you want to save a snapshot
|
2012-12-03 22:56:49 -05:00
|
|
|
of your project with the <code>git commit</code> command and it basically
|
|
|
|
records a manifest of what all of the files in your project look like at
|
2010-06-03 14:34:35 +02:00
|
|
|
that point. Then most of the commands work with those manifests to see
|
2012-12-03 22:56:49 -05:00
|
|
|
how they differ or pull content out of them, etc.
|
2010-06-03 14:34:35 +02:00
|
|
|
</p>
|
|
|
|
|
2010-09-26 10:47:21 +05:30
|
|
|
<center><img src="./images/snapshots.png"/></center>
|
2010-06-03 14:34:35 +02:00
|
|
|
|
|
|
|
<p>
|
|
|
|
If you think about Git
|
|
|
|
as a tool for storing and comparing and merging snapshots of your project,
|
2012-12-03 22:56:49 -05:00
|
|
|
it may be easier to understand what is going on and how to do things
|
2010-06-03 14:34:35 +02:00
|
|
|
properly.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
2010-06-03 16:25:55 +02:00
|
|
|
|
2011-03-02 03:04:18 -05:00
|
|
|
<p><a class="page-button next-page" href="/creating">On to Getting and Creating Projects »</a></p>
|