Merge branch 'wk/user-manual-literal-format' into maint

* wk/user-manual-literal-format:
  user-manual: Standardize backtick quoting
This commit is contained in:
Junio C Hamano 2013-03-26 12:40:11 -07:00
commit 273ca55907

View File

@ -19,7 +19,7 @@ Further chapters cover more specialized topics.
Comprehensive reference documentation is available through the man Comprehensive reference documentation is available through the man
pages, or linkgit:git-help[1] command. For example, for the command pages, or linkgit:git-help[1] command. For example, for the command
"git clone <repo>", you can either use: `git clone <repo>`, you can either use:
------------------------------------------------ ------------------------------------------------
$ man git-clone $ man git-clone
@ -66,11 +66,11 @@ $ git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
The initial clone may be time-consuming for a large project, but you The initial clone may be time-consuming for a large project, but you
will only need to clone once. will only need to clone once.
The clone command creates a new directory named after the project ("git" The clone command creates a new directory named after the project (`git`
or "linux-2.6" in the examples above). After you cd into this or `linux-2.6` in the examples above). After you cd into this
directory, you will see that it contains a copy of the project files, directory, you will see that it contains a copy of the project files,
called the <<def_working_tree,working tree>>, together with a special called the <<def_working_tree,working tree>>, together with a special
top-level directory named ".git", which contains all the information top-level directory named `.git`, which contains all the information
about the history of the project. about the history of the project.
[[how-to-check-out]] [[how-to-check-out]]
@ -188,7 +188,7 @@ As you can see, a commit shows who made the latest change, what they
did, and why. did, and why.
Every commit has a 40-hexdigit id, sometimes called the "object name" or the Every commit has a 40-hexdigit id, sometimes called the "object name" or the
"SHA-1 id", shown on the first line of the "git show" output. You can usually "SHA-1 id", shown on the first line of the `git show` output. You can usually
refer to a commit by a shorter name, such as a tag or a branch name, but this refer to a commit by a shorter name, such as a tag or a branch name, but this
longer name can also be useful. Most importantly, it is a globally unique longer name can also be useful. Most importantly, it is a globally unique
name for this commit: so if you tell somebody else the object name (for name for this commit: so if you tell somebody else the object name (for
@ -268,35 +268,35 @@ Manipulating branches
Creating, deleting, and modifying branches is quick and easy; here's Creating, deleting, and modifying branches is quick and easy; here's
a summary of the commands: a summary of the commands:
git branch:: `git branch`::
list all branches list all branches
git branch <branch>:: `git branch <branch>`::
create a new branch named <branch>, referencing the same create a new branch named `<branch>`, referencing the same
point in history as the current branch point in history as the current branch
git branch <branch> <start-point>:: `git branch <branch> <start-point>`::
create a new branch named <branch>, referencing create a new branch named `<branch>`, referencing
<start-point>, which may be specified any way you like, `<start-point>`, which may be specified any way you like,
including using a branch name or a tag name including using a branch name or a tag name
git branch -d <branch>:: `git branch -d <branch>`::
delete the branch <branch>; if the branch you are deleting delete the branch `<branch>`; if the branch you are deleting
points to a commit which is not reachable from the current points to a commit which is not reachable from the current
branch, this command will fail with a warning. branch, this command will fail with a warning.
git branch -D <branch>:: `git branch -D <branch>`::
even if the branch points to a commit not reachable even if the branch points to a commit not reachable
from the current branch, you may know that that commit from the current branch, you may know that that commit
is still reachable from some other branch or tag. In that is still reachable from some other branch or tag. In that
case it is safe to use this command to force Git to delete case it is safe to use this command to force Git to delete
the branch. the branch.
git checkout <branch>:: `git checkout <branch>`::
make the current branch <branch>, updating the working make the current branch `<branch>`, updating the working
directory to reflect the version referenced by <branch> directory to reflect the version referenced by `<branch>`
git checkout -b <new> <start-point>:: `git checkout -b <new> <start-point>`::
create a new branch <new> referencing <start-point>, and create a new branch `<new>` referencing `<start-point>`, and
check it out. check it out.
The special symbol "HEAD" can always be used to refer to the current The special symbol "HEAD" can always be used to refer to the current
branch. In fact, Git uses a file named "HEAD" in the .git directory to branch. In fact, Git uses a file named `HEAD` in the `.git` directory
remember which branch is current: to remember which branch is current:
------------------------------------------------ ------------------------------------------------
$ cat .git/HEAD $ cat .git/HEAD
@ -346,7 +346,7 @@ of the HEAD in the repository that you cloned from. That repository
may also have had other branches, though, and your local repository may also have had other branches, though, and your local repository
keeps branches which track each of those remote branches, called keeps branches which track each of those remote branches, called
remote-tracking branches, which you remote-tracking branches, which you
can view using the "-r" option to linkgit:git-branch[1]: can view using the `-r` option to linkgit:git-branch[1]:
------------------------------------------------ ------------------------------------------------
$ git branch -r $ git branch -r
@ -364,7 +364,7 @@ In this example, "origin" is called a remote repository, or "remote"
for short. The branches of this repository are called "remote for short. The branches of this repository are called "remote
branches" from our point of view. The remote-tracking branches listed branches" from our point of view. The remote-tracking branches listed
above were created based on the remote branches at clone time and will above were created based on the remote branches at clone time and will
be updated by "git fetch" (hence "git pull") and "git push". See be updated by `git fetch` (hence `git pull`) and `git push`. See
<<Updating-a-repository-With-git-fetch>> for details. <<Updating-a-repository-With-git-fetch>> for details.
You might want to build on one of these remote-tracking branches You might want to build on one of these remote-tracking branches
@ -374,7 +374,7 @@ on a branch of your own, just as you would for a tag:
$ git checkout -b my-todo-copy origin/todo $ git checkout -b my-todo-copy origin/todo
------------------------------------------------ ------------------------------------------------
You can also check out "origin/todo" directly to examine it or You can also check out `origin/todo` directly to examine it or
write a one-off patch. See <<detached-head,detached head>>. write a one-off patch. See <<detached-head,detached head>>.
Note that the name "origin" is just the name that Git uses by default Note that the name "origin" is just the name that Git uses by default
@ -386,17 +386,17 @@ Naming branches, tags, and other references
Branches, remote-tracking branches, and tags are all references to Branches, remote-tracking branches, and tags are all references to
commits. All references are named with a slash-separated path name commits. All references are named with a slash-separated path name
starting with "refs"; the names we've been using so far are actually starting with `refs`; the names we've been using so far are actually
shorthand: shorthand:
- The branch "test" is short for "refs/heads/test". - The branch `test` is short for `refs/heads/test`.
- The tag "v2.6.18" is short for "refs/tags/v2.6.18". - The tag `v2.6.18` is short for `refs/tags/v2.6.18`.
- "origin/master" is short for "refs/remotes/origin/master". - `origin/master` is short for `refs/remotes/origin/master`.
The full name is occasionally useful if, for example, there ever The full name is occasionally useful if, for example, there ever
exists a tag and a branch with the same name. exists a tag and a branch with the same name.
(Newly created refs are actually stored in the .git/refs directory, (Newly created refs are actually stored in the `.git/refs` directory,
under the path given by their name. However, for efficiency reasons under the path given by their name. However, for efficiency reasons
they may also be packed together in a single file; see they may also be packed together in a single file; see
linkgit:git-pack-refs[1]). linkgit:git-pack-refs[1]).
@ -418,7 +418,7 @@ Eventually the developer cloned from will do additional work in her
repository, creating new commits and advancing the branches to point repository, creating new commits and advancing the branches to point
at the new commits. at the new commits.
The command "git fetch", with no arguments, will update all of the The command `git fetch`, with no arguments, will update all of the
remote-tracking branches to the latest version found in her remote-tracking branches to the latest version found in her
repository. It will not touch any of your own branches--not even the repository. It will not touch any of your own branches--not even the
"master" branch that was created for you on clone. "master" branch that was created for you on clone.
@ -438,7 +438,7 @@ $ git fetch linux-nfs
------------------------------------------------- -------------------------------------------------
New remote-tracking branches will be stored under the shorthand name New remote-tracking branches will be stored under the shorthand name
that you gave "git remote add", in this case linux-nfs: that you gave `git remote add`, in this case `linux-nfs`:
------------------------------------------------- -------------------------------------------------
$ git branch -r $ git branch -r
@ -446,10 +446,10 @@ linux-nfs/master
origin/master origin/master
------------------------------------------------- -------------------------------------------------
If you run "git fetch <remote>" later, the remote-tracking branches for the If you run `git fetch <remote>` later, the remote-tracking branches
named <remote> will be updated. for the named `<remote>` will be updated.
If you examine the file .git/config, you will see that Git has added If you examine the file `.git/config`, you will see that Git has added
a new stanza: a new stanza:
------------------------------------------------- -------------------------------------------------
@ -462,7 +462,7 @@ $ cat .git/config
------------------------------------------------- -------------------------------------------------
This is what causes Git to track the remote's branches; you may modify This is what causes Git to track the remote's branches; you may modify
or delete these configuration options by editing .git/config with a or delete these configuration options by editing `.git/config` with a
text editor. (See the "CONFIGURATION FILE" section of text editor. (See the "CONFIGURATION FILE" section of
linkgit:git-config[1] for details.) linkgit:git-config[1] for details.)
@ -499,7 +499,7 @@ Bisecting: 3537 revisions left to test after this
[65934a9a028b88e83e2b0f8b36618fe503349f8e] BLOCK: Make USB storage depend on SCSI rather than selecting it [try #6] [65934a9a028b88e83e2b0f8b36618fe503349f8e] BLOCK: Make USB storage depend on SCSI rather than selecting it [try #6]
------------------------------------------------- -------------------------------------------------
If you run "git branch" at this point, you'll see that Git has If you run `git branch` at this point, you'll see that Git has
temporarily moved you in "(no branch)". HEAD is now detached from any temporarily moved you in "(no branch)". HEAD is now detached from any
branch and points directly to a commit (with commit id 65934...) that branch and points directly to a commit (with commit id 65934...) that
is reachable from "master" but not from v2.6.18. Compile and test it, is reachable from "master" but not from v2.6.18. Compile and test it,
@ -545,11 +545,11 @@ id, and check it out with:
$ git reset --hard fb47ddb2db... $ git reset --hard fb47ddb2db...
------------------------------------------------- -------------------------------------------------
then test, run "bisect good" or "bisect bad" as appropriate, and then test, run `bisect good` or `bisect bad` as appropriate, and
continue. continue.
Instead of "git bisect visualize" and then "git reset --hard Instead of `git bisect visualize` and then `git reset --hard
fb47ddb2db...", you might just want to tell Git that you want to skip fb47ddb2db...`, you might just want to tell Git that you want to skip
the current commit: the current commit:
------------------------------------------------- -------------------------------------------------
@ -561,8 +561,8 @@ bad one between some first skipped commits and a later bad commit.
There are also ways to automate the bisecting process if you have a There are also ways to automate the bisecting process if you have a
test script that can tell a good from a bad commit. See test script that can tell a good from a bad commit. See
linkgit:git-bisect[1] for more information about this and other "git linkgit:git-bisect[1] for more information about this and other `git
bisect" features. bisect` features.
[[naming-commits]] [[naming-commits]]
Naming commits Naming commits
@ -591,7 +591,7 @@ $ git show HEAD~4 # the great-great-grandparent
------------------------------------------------- -------------------------------------------------
Recall that merge commits may have more than one parent; by default, Recall that merge commits may have more than one parent; by default,
^ and ~ follow the first parent listed in the commit, but you can `^` and `~` follow the first parent listed in the commit, but you can
also choose: also choose:
------------------------------------------------- -------------------------------------------------
@ -640,7 +640,7 @@ running
$ git tag stable-1 1b2e1d63ff $ git tag stable-1 1b2e1d63ff
------------------------------------------------- -------------------------------------------------
You can use stable-1 to refer to the commit 1b2e1d63ff. You can use `stable-1` to refer to the commit 1b2e1d63ff.
This creates a "lightweight" tag. If you would also like to include a This creates a "lightweight" tag. If you would also like to include a
comment with the tag, and possibly sign it cryptographically, then you comment with the tag, and possibly sign it cryptographically, then you
@ -669,7 +669,7 @@ $ git log -S'foo()' # commits which add or remove any file data
------------------------------------------------- -------------------------------------------------
And of course you can combine all of these; the following finds And of course you can combine all of these; the following finds
commits since v2.5 which touch the Makefile or any file under fs: commits since v2.5 which touch the `Makefile` or any file under `fs`:
------------------------------------------------- -------------------------------------------------
$ git log v2.5.. Makefile fs/ $ git log v2.5.. Makefile fs/
@ -681,7 +681,7 @@ You can also ask git log to show patches:
$ git log -p $ git log -p
------------------------------------------------- -------------------------------------------------
See the "--pretty" option in the linkgit:git-log[1] man page for more See the `--pretty` option in the linkgit:git-log[1] man page for more
display options. display options.
Note that git log starts with the most recent commit and works Note that git log starts with the most recent commit and works
@ -742,8 +742,8 @@ Examples
Counting the number of commits on a branch Counting the number of commits on a branch
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Suppose you want to know how many commits you've made on "mybranch" Suppose you want to know how many commits you've made on `mybranch`
since it diverged from "origin": since it diverged from `origin`:
------------------------------------------------- -------------------------------------------------
$ git log --pretty=oneline origin..mybranch | wc -l $ git log --pretty=oneline origin..mybranch | wc -l
@ -780,7 +780,7 @@ $ git rev-list master
e05db0fd4f31dde7005f075a84f96b360d05984b e05db0fd4f31dde7005f075a84f96b360d05984b
------------------------------------------------- -------------------------------------------------
Or you could recall that the ... operator selects all commits Or you could recall that the `...` operator selects all commits
contained reachable from either one reference or the other but not contained reachable from either one reference or the other but not
both; so both; so
@ -880,7 +880,7 @@ Showing commits unique to a given branch
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Suppose you would like to see all the commits reachable from the branch Suppose you would like to see all the commits reachable from the branch
head named "master" but not from any other head in your repository. head named `master` but not from any other head in your repository.
We can list all the heads in this repository with We can list all the heads in this repository with
linkgit:git-show-ref[1]: linkgit:git-show-ref[1]:
@ -894,7 +894,7 @@ a07157ac624b2524a059a3414e99f6f44bebc1e7 refs/heads/master
1e87486ae06626c2f31eaa63d26fc0fd646c8af2 refs/heads/tutorial-fixes 1e87486ae06626c2f31eaa63d26fc0fd646c8af2 refs/heads/tutorial-fixes
------------------------------------------------- -------------------------------------------------
We can get just the branch-head names, and remove "master", with We can get just the branch-head names, and remove `master`, with
the help of the standard utilities cut and grep: the help of the standard utilities cut and grep:
------------------------------------------------- -------------------------------------------------
@ -939,7 +939,7 @@ is preceded by `project/`. The output file format is inferred from
the output file extension if possible, see linkgit:git-archive[1] for the output file extension if possible, see linkgit:git-archive[1] for
details. details.
Versions of Git older than 1.7.7 don't know about the 'tar.gz' format, Versions of Git older than 1.7.7 don't know about the `tar.gz` format,
you'll need to use gzip explicitly: you'll need to use gzip explicitly:
------------------------------------------------- -------------------------------------------------
@ -1062,7 +1062,7 @@ at step 3, Git maintains a snapshot of the tree's contents in a
special staging area called "the index." special staging area called "the index."
At the beginning, the content of the index will be identical to At the beginning, the content of the index will be identical to
that of the HEAD. The command "git diff --cached", which shows that of the HEAD. The command `git diff --cached`, which shows
the difference between the HEAD and the index, should therefore the difference between the HEAD and the index, should therefore
produce no output at that point. produce no output at that point.
@ -1101,7 +1101,7 @@ $ git diff
shows the difference between the working tree and the index file. shows the difference between the working tree and the index file.
Note that "git add" always adds just the current contents of a file Note that `git add` always adds just the current contents of a file
to the index; further changes to the same file will be ignored unless to the index; further changes to the same file will be ignored unless
you run `git add` on the file again. you run `git add` on the file again.
@ -1172,8 +1172,9 @@ annoying to have these untracked files lying around; e.g. they make
`git add .` practically useless, and they keep showing up in the output of `git add .` practically useless, and they keep showing up in the output of
`git status`. `git status`.
You can tell Git to ignore certain files by creating a file called .gitignore You can tell Git to ignore certain files by creating a file called
in the top level of your working directory, with contents such as: `.gitignore` in the top level of your working directory, with contents
such as:
------------------------------------------------- -------------------------------------------------
# Lines starting with '#' are considered comments. # Lines starting with '#' are considered comments.
@ -1197,10 +1198,10 @@ for other users who clone your repository.
If you wish the exclude patterns to affect only certain repositories If you wish the exclude patterns to affect only certain repositories
(instead of every repository for a given project), you may instead put (instead of every repository for a given project), you may instead put
them in a file in your repository named .git/info/exclude, or in any file them in a file in your repository named `.git/info/exclude`, or in any
specified by the `core.excludesfile` configuration variable. Some Git file specified by the `core.excludesfile` configuration variable.
commands can also take exclude patterns directly on the command line. Some Git commands can also take exclude patterns directly on the
See linkgit:gitignore[5] for the details. command line. See linkgit:gitignore[5] for the details.
[[how-to-merge]] [[how-to-merge]]
How to merge How to merge
@ -1213,10 +1214,10 @@ linkgit:git-merge[1]:
$ git merge branchname $ git merge branchname
------------------------------------------------- -------------------------------------------------
merges the development in the branch "branchname" into the current merges the development in the branch `branchname` into the current
branch. branch.
A merge is made by combining the changes made in "branchname" and the A merge is made by combining the changes made in `branchname` and the
changes made up to the latest commit in your current branch since changes made up to the latest commit in your current branch since
their histories forked. The work tree is overwritten by the result of their histories forked. The work tree is overwritten by the result of
the merge when this combining is done cleanly, or overwritten by a the merge when this combining is done cleanly, or overwritten by a
@ -1338,7 +1339,7 @@ that part is not conflicting and is not shown. Same for stage 3).
The diff above shows the differences between the working-tree version of The diff above shows the differences between the working-tree version of
file.txt and the stage 2 and stage 3 versions. So instead of preceding file.txt and the stage 2 and stage 3 versions. So instead of preceding
each line by a single "+" or "-", it now uses two columns: the first each line by a single `+` or `-`, it now uses two columns: the first
column is used for differences between the first parent and the working column is used for differences between the first parent and the working
directory copy, and the second for differences between the second parent directory copy, and the second for differences between the second parent
and the working directory copy. (See the "COMBINED DIFF FORMAT" section and the working directory copy. (See the "COMBINED DIFF FORMAT" section
@ -1613,7 +1614,7 @@ dangling tree b24c2473f1fd3d91352a624795be026d64c8841f
You will see informational messages on dangling objects. They are objects You will see informational messages on dangling objects. They are objects
that still exist in the repository but are no longer referenced by any of that still exist in the repository but are no longer referenced by any of
your branches, and can (and will) be removed after a while with "gc". your branches, and can (and will) be removed after a while with `gc`.
You can run `git fsck --no-dangling` to suppress these messages, and still You can run `git fsck --no-dangling` to suppress these messages, and still
view real errors. view real errors.
@ -1625,9 +1626,9 @@ Recovering lost changes
Reflogs Reflogs
^^^^^^^ ^^^^^^^
Say you modify a branch with +linkgit:git-reset[1] \--hard+, and then Say you modify a branch with <<fixing-mistakes,`git reset --hard`>>,
realize that the branch was the only reference you had to that point in and then realize that the branch was the only reference you had to
history. that point in history.
Fortunately, Git also keeps a log, called a "reflog", of all the Fortunately, Git also keeps a log, called a "reflog", of all the
previous values of each branch. So in this case you can still find the previous values of each branch. So in this case you can still find the
@ -1638,8 +1639,8 @@ $ git log master@{1}
------------------------------------------------- -------------------------------------------------
This lists the commits reachable from the previous version of the This lists the commits reachable from the previous version of the
"master" branch head. This syntax can be used with any Git command `master` branch head. This syntax can be used with any Git command
that accepts a commit, not just with git log. Some other examples: that accepts a commit, not just with `git log`. Some other examples:
------------------------------------------------- -------------------------------------------------
$ git show master@{2} # See where the branch pointed 2, $ git show master@{2} # See where the branch pointed 2,
@ -1743,8 +1744,8 @@ one step:
$ git pull origin master $ git pull origin master
------------------------------------------------- -------------------------------------------------
In fact, if you have "master" checked out, then this branch has been In fact, if you have `master` checked out, then this branch has been
configured by "git clone" to get changes from the HEAD branch of the configured by `git clone` to get changes from the HEAD branch of the
origin repository. So often you can origin repository. So often you can
accomplish the above with just a simple accomplish the above with just a simple
@ -1759,11 +1760,11 @@ the current branch.
More generally, a branch that is created from a remote-tracking branch More generally, a branch that is created from a remote-tracking branch
will pull will pull
by default from that branch. See the descriptions of the by default from that branch. See the descriptions of the
branch.<name>.remote and branch.<name>.merge options in `branch.<name>.remote` and `branch.<name>.merge` options in
linkgit:git-config[1], and the discussion of the `--track` option in linkgit:git-config[1], and the discussion of the `--track` option in
linkgit:git-checkout[1], to learn how to control these defaults. linkgit:git-checkout[1], to learn how to control these defaults.
In addition to saving you keystrokes, "git pull" also helps you by In addition to saving you keystrokes, `git pull` also helps you by
producing a default commit message documenting the branch and producing a default commit message documenting the branch and
repository that you pulled from. repository that you pulled from.
@ -1771,7 +1772,7 @@ repository that you pulled from.
<<fast-forwards,fast-forward>>; instead, your branch will just be <<fast-forwards,fast-forward>>; instead, your branch will just be
updated to point to the latest commit from the upstream branch.) updated to point to the latest commit from the upstream branch.)
The `git pull` command can also be given "." as the "remote" repository, The `git pull` command can also be given `.` as the "remote" repository,
in which case it just merges in a branch from the current repository; so in which case it just merges in a branch from the current repository; so
the commands the commands
@ -1796,7 +1797,7 @@ $ git format-patch origin
------------------------------------------------- -------------------------------------------------
will produce a numbered series of files in the current directory, one will produce a numbered series of files in the current directory, one
for each patch in the current branch but not in origin/HEAD. for each patch in the current branch but not in `origin/HEAD`.
`git format-patch` can include an initial "cover letter". You can insert `git format-patch` can include an initial "cover letter". You can insert
commentary on individual patches after the three dash line which commentary on individual patches after the three dash line which
@ -1818,7 +1819,7 @@ Importing patches to a project
Git also provides a tool called linkgit:git-am[1] (am stands for Git also provides a tool called linkgit:git-am[1] (am stands for
"apply mailbox"), for importing such an emailed series of patches. "apply mailbox"), for importing such an emailed series of patches.
Just save all of the patch-containing messages, in order, into a Just save all of the patch-containing messages, in order, into a
single mailbox file, say "patches.mbox", then run single mailbox file, say `patches.mbox`, then run
------------------------------------------------- -------------------------------------------------
$ git am -3 patches.mbox $ git am -3 patches.mbox
@ -1826,7 +1827,7 @@ $ git am -3 patches.mbox
Git will apply each patch in order; if any conflicts are found, it Git will apply each patch in order; if any conflicts are found, it
will stop, and you can fix the conflicts as described in will stop, and you can fix the conflicts as described in
"<<resolving-a-merge,Resolving a merge>>". (The "-3" option tells "<<resolving-a-merge,Resolving a merge>>". (The `-3` option tells
Git to perform a merge; if you would prefer it just to abort and Git to perform a merge; if you would prefer it just to abort and
leave your tree and index untouched, you may omit that option.) leave your tree and index untouched, you may omit that option.)
@ -1902,7 +1903,7 @@ We explain how to do this in the following sections.
Setting up a public repository Setting up a public repository
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Assume your personal repository is in the directory ~/proj. We Assume your personal repository is in the directory `~/proj`. We
first create a new clone of the repository and tell `git daemon` that it first create a new clone of the repository and tell `git daemon` that it
is meant to be public: is meant to be public:
@ -1912,10 +1913,10 @@ $ touch proj.git/git-daemon-export-ok
------------------------------------------------- -------------------------------------------------
The resulting directory proj.git contains a "bare" git repository--it is The resulting directory proj.git contains a "bare" git repository--it is
just the contents of the ".git" directory, without any files checked out just the contents of the `.git` directory, without any files checked out
around it. around it.
Next, copy proj.git to the server where you plan to host the Next, copy `proj.git` to the server where you plan to host the
public repository. You can use scp, rsync, or whatever is most public repository. You can use scp, rsync, or whatever is most
convenient. convenient.
@ -1926,8 +1927,8 @@ Exporting a Git repository via the Git protocol
This is the preferred method. This is the preferred method.
If someone else administers the server, they should tell you what If someone else administers the server, they should tell you what
directory to put the repository in, and what git:// URL it will appear directory to put the repository in, and what `git://` URL it will
at. You can then skip to the section appear at. You can then skip to the section
"<<pushing-changes-to-a-public-repository,Pushing changes to a public "<<pushing-changes-to-a-public-repository,Pushing changes to a public
repository>>", below. repository>>", below.
@ -1962,7 +1963,7 @@ $ mv hooks/post-update.sample hooks/post-update
(For an explanation of the last two lines, see (For an explanation of the last two lines, see
linkgit:git-update-server-info[1] and linkgit:githooks[5].) linkgit:git-update-server-info[1] and linkgit:githooks[5].)
Advertise the URL of proj.git. Anybody else should then be able to Advertise the URL of `proj.git`. Anybody else should then be able to
clone or pull from that URL, for example with a command line like: clone or pull from that URL, for example with a command line like:
------------------------------------------------- -------------------------------------------------
@ -1985,8 +1986,8 @@ access, which you will need to update the public repository with the
latest changes created in your private repository. latest changes created in your private repository.
The simplest way to do this is using linkgit:git-push[1] and ssh; to The simplest way to do this is using linkgit:git-push[1] and ssh; to
update the remote branch named "master" with the latest state of your update the remote branch named `master` with the latest state of your
branch named "master", run branch named `master`, run
------------------------------------------------- -------------------------------------------------
$ git push ssh://yourserver.com/~you/proj.git master:master $ git push ssh://yourserver.com/~you/proj.git master:master
@ -2002,7 +2003,7 @@ As with `git fetch`, `git push` will complain if this does not result in a
<<fast-forwards,fast-forward>>; see the following section for details on <<fast-forwards,fast-forward>>; see the following section for details on
handling this case. handling this case.
Note that the target of a "push" is normally a Note that the target of a `push` is normally a
<<def_bare_repository,bare>> repository. You can also push to a <<def_bare_repository,bare>> repository. You can also push to a
repository that has a checked-out working tree, but a push to update the repository that has a checked-out working tree, but a push to update the
currently checked-out branch is denied by default to prevent confusion. currently checked-out branch is denied by default to prevent confusion.
@ -2030,9 +2031,9 @@ which lets you do the same push with just
$ git push public-repo master $ git push public-repo master
------------------------------------------------- -------------------------------------------------
See the explanations of the remote.<name>.url, branch.<name>.remote, See the explanations of the `remote.<name>.url`,
and remote.<name>.push options in linkgit:git-config[1] for `branch.<name>.remote`, and `remote.<name>.push` options in
details. linkgit:git-config[1] for details.
[[forcing-push]] [[forcing-push]]
What to do when a push fails What to do when a push fails
@ -2167,7 +2168,7 @@ linkgit:git-fetch[1] to keep them up-to-date; see
Now create the branches in which you are going to work; these start out Now create the branches in which you are going to work; these start out
at the current tip of origin/master branch, and should be set up (using at the current tip of origin/master branch, and should be set up (using
the --track option to linkgit:git-branch[1]) to merge changes in from the `--track` option to linkgit:git-branch[1]) to merge changes in from
Linus by default. Linus by default.
------------------------------------------------- -------------------------------------------------
@ -2186,7 +2187,7 @@ Important note! If you have any local changes in these branches, then
this merge will create a commit object in the history (with no local this merge will create a commit object in the history (with no local
changes Git will simply do a "fast-forward" merge). Many people dislike changes Git will simply do a "fast-forward" merge). Many people dislike
the "noise" that this creates in the Linux history, so you should avoid the "noise" that this creates in the Linux history, so you should avoid
doing this capriciously in the "release" branch, as these noisy commits doing this capriciously in the `release` branch, as these noisy commits
will become part of the permanent history when you ask Linus to pull will become part of the permanent history when you ask Linus to pull
from the release branch. from the release branch.
@ -2228,7 +2229,7 @@ patches), and create a new branch from a recent stable tag of
Linus's branch. Picking a stable base for your branch will: Linus's branch. Picking a stable base for your branch will:
1) help you: by avoiding inclusion of unrelated and perhaps lightly 1) help you: by avoiding inclusion of unrelated and perhaps lightly
tested changes tested changes
2) help future bug hunters that use "git bisect" to find problems 2) help future bug hunters that use `git bisect` to find problems
------------------------------------------------- -------------------------------------------------
$ git checkout -b speed-up-spinlocks v2.6.35 $ git checkout -b speed-up-spinlocks v2.6.35
@ -2253,9 +2254,9 @@ It is unlikely that you would have any conflicts here ... but you might if you
spent a while on this step and had also pulled new versions from upstream. spent a while on this step and had also pulled new versions from upstream.
Some time later when enough time has passed and testing done, you can pull the Some time later when enough time has passed and testing done, you can pull the
same branch into the "release" tree ready to go upstream. This is where you same branch into the `release` tree ready to go upstream. This is where you
see the value of keeping each patch (or patch series) in its own branch. It see the value of keeping each patch (or patch series) in its own branch. It
means that the patches can be moved into the "release" tree in any order. means that the patches can be moved into the `release` tree in any order.
------------------------------------------------- -------------------------------------------------
$ git checkout release && git pull . speed-up-spinlocks $ git checkout release && git pull . speed-up-spinlocks
@ -2288,7 +2289,7 @@ If it has been merged, then there will be no output.)
Once a patch completes the great cycle (moving from test to release, Once a patch completes the great cycle (moving from test to release,
then pulled by Linus, and finally coming back into your local then pulled by Linus, and finally coming back into your local
"origin/master" branch), the branch for this change is no longer needed. `origin/master` branch), the branch for this change is no longer needed.
You detect this when the output from: You detect this when the output from:
------------------------------------------------- -------------------------------------------------
@ -2303,8 +2304,8 @@ $ git branch -d branchname
Some changes are so trivial that it is not necessary to create a separate Some changes are so trivial that it is not necessary to create a separate
branch and then merge into each of the test and release branches. For branch and then merge into each of the test and release branches. For
these changes, just apply directly to the "release" branch, and then these changes, just apply directly to the `release` branch, and then
merge that into the "test" branch. merge that into the `test` branch.
After pushing your work to `mytree`, you can use After pushing your work to `mytree`, you can use
linkgit:git-request-pull[1] to prepare a "please pull" request message linkgit:git-request-pull[1] to prepare a "please pull" request message
@ -2475,8 +2476,8 @@ you are rewriting history.
Keeping a patch series up to date using git rebase Keeping a patch series up to date using git rebase
-------------------------------------------------- --------------------------------------------------
Suppose that you create a branch "mywork" on a remote-tracking branch Suppose that you create a branch `mywork` on a remote-tracking branch
"origin", and create some commits on top of it: `origin`, and create some commits on top of it:
------------------------------------------------- -------------------------------------------------
$ git checkout -b mywork origin $ git checkout -b mywork origin
@ -2488,7 +2489,7 @@ $ git commit
------------------------------------------------- -------------------------------------------------
You have performed no merges into mywork, so it is just a simple linear You have performed no merges into mywork, so it is just a simple linear
sequence of patches on top of "origin": sequence of patches on top of `origin`:
................................................ ................................................
o--o--O <-- origin o--o--O <-- origin
@ -2497,7 +2498,7 @@ sequence of patches on top of "origin":
................................................ ................................................
Some more interesting work has been done in the upstream project, and Some more interesting work has been done in the upstream project, and
"origin" has advanced: `origin` has advanced:
................................................ ................................................
o--o--O--o--o--o <-- origin o--o--O--o--o--o <-- origin
@ -2505,7 +2506,7 @@ Some more interesting work has been done in the upstream project, and
a--b--c <-- mywork a--b--c <-- mywork
................................................ ................................................
At this point, you could use "pull" to merge your changes back in; At this point, you could use `pull` to merge your changes back in;
the result would create a new merge commit, like this: the result would create a new merge commit, like this:
................................................ ................................................
@ -2524,7 +2525,7 @@ $ git rebase origin
------------------------------------------------- -------------------------------------------------
This will remove each of your commits from mywork, temporarily saving This will remove each of your commits from mywork, temporarily saving
them as patches (in a directory named ".git/rebase-apply"), update mywork to them as patches (in a directory named `.git/rebase-apply`), update mywork to
point at the latest version of origin, then apply each of the saved point at the latest version of origin, then apply each of the saved
patches to the new mywork. The result will look like: patches to the new mywork. The result will look like:
@ -2795,10 +2796,10 @@ arbitrary name:
$ git fetch origin todo:my-todo-work $ git fetch origin todo:my-todo-work
------------------------------------------------- -------------------------------------------------
The first argument, "origin", just tells Git to fetch from the The first argument, `origin`, just tells Git to fetch from the
repository you originally cloned from. The second argument tells Git repository you originally cloned from. The second argument tells Git
to fetch the branch named "todo" from the remote repository, and to to fetch the branch named `todo` from the remote repository, and to
store it locally under the name refs/heads/my-todo-work. store it locally under the name `refs/heads/my-todo-work`.
You can also fetch branches from other repositories; so You can also fetch branches from other repositories; so
@ -2806,8 +2807,8 @@ You can also fetch branches from other repositories; so
$ git fetch git://example.com/proj.git master:example-master $ git fetch git://example.com/proj.git master:example-master
------------------------------------------------- -------------------------------------------------
will create a new branch named "example-master" and store in it the will create a new branch named `example-master` and store in it the
branch named "master" from the repository at the given URL. If you branch named `master` from the repository at the given URL. If you
already have a branch named example-master, it will attempt to already have a branch named example-master, it will attempt to
<<fast-forwards,fast-forward>> to the commit given by example.com's <<fast-forwards,fast-forward>> to the commit given by example.com's
master branch. In more detail: master branch. In more detail:
@ -2816,7 +2817,7 @@ master branch. In more detail:
git fetch and fast-forwards git fetch and fast-forwards
--------------------------- ---------------------------
In the previous example, when updating an existing branch, "git fetch" In the previous example, when updating an existing branch, `git fetch`
checks to make sure that the most recent commit on the remote checks to make sure that the most recent commit on the remote
branch is a descendant of the most recent commit on your copy of the branch is a descendant of the most recent commit on your copy of the
branch before updating your copy of the branch to point at the new branch before updating your copy of the branch to point at the new
@ -2842,11 +2843,11 @@ resulting in a situation like:
o--o--o <-- new head of the branch o--o--o <-- new head of the branch
................................................ ................................................
In this case, "git fetch" will fail, and print out a warning. In this case, `git fetch` will fail, and print out a warning.
In that case, you can still force Git to update to the new head, as In that case, you can still force Git to update to the new head, as
described in the following section. However, note that in the described in the following section. However, note that in the
situation above this may mean losing the commits labeled "a" and "b", situation above this may mean losing the commits labeled `a` and `b`,
unless you've already created a reference of your own pointing to unless you've already created a reference of your own pointing to
them. them.
@ -2861,7 +2862,7 @@ descendant of the old head, you may force the update with:
$ git fetch git://example.com/proj.git +master:refs/remotes/example/master $ git fetch git://example.com/proj.git +master:refs/remotes/example/master
------------------------------------------------- -------------------------------------------------
Note the addition of the "+" sign. Alternatively, you can use the "-f" Note the addition of the `+` sign. Alternatively, you can use the `-f`
flag to force updates of all the fetched branches, as in: flag to force updates of all the fetched branches, as in:
------------------------------------------------- -------------------------------------------------
@ -2875,7 +2876,7 @@ may be lost, as we saw in the previous section.
Configuring remote-tracking branches Configuring remote-tracking branches
------------------------------------ ------------------------------------
We saw above that "origin" is just a shortcut to refer to the We saw above that `origin` is just a shortcut to refer to the
repository that you originally cloned from. This information is repository that you originally cloned from. This information is
stored in Git configuration variables, which you can see using stored in Git configuration variables, which you can see using
linkgit:git-config[1]: linkgit:git-config[1]:
@ -2984,7 +2985,7 @@ Commit Object
~~~~~~~~~~~~~ ~~~~~~~~~~~~~
The "commit" object links a physical state of a tree with a description The "commit" object links a physical state of a tree with a description
of how we got there and why. Use the --pretty=raw option to of how we got there and why. Use the `--pretty=raw` option to
linkgit:git-show[1] or linkgit:git-log[1] to examine your favorite linkgit:git-show[1] or linkgit:git-log[1] to examine your favorite
commit: commit:
@ -3026,7 +3027,7 @@ of the tree referred to by this commit with the trees associated with
its parents. In particular, Git does not attempt to record file renames its parents. In particular, Git does not attempt to record file renames
explicitly, though it can identify cases where the existence of the same explicitly, though it can identify cases where the existence of the same
file data at changing paths suggests a rename. (See, for example, the file data at changing paths suggests a rename. (See, for example, the
-M option to linkgit:git-diff[1]). `-M` option to linkgit:git-diff[1]).
A commit is usually created by linkgit:git-commit[1], which creates a A commit is usually created by linkgit:git-commit[1], which creates a
commit whose parent is normally the current HEAD, and whose tree is commit whose parent is normally the current HEAD, and whose tree is
@ -3077,7 +3078,7 @@ Blob Object
~~~~~~~~~~~ ~~~~~~~~~~~
You can use linkgit:git-show[1] to examine the contents of a blob; take, You can use linkgit:git-show[1] to examine the contents of a blob; take,
for example, the blob in the entry for "COPYING" from the tree above: for example, the blob in the entry for `COPYING` from the tree above:
------------------------------------------------ ------------------------------------------------
$ git show 6ff87c4664 $ git show 6ff87c4664
@ -3160,14 +3161,14 @@ nLE/L9aUXdWeTFPron96DLA=
See the linkgit:git-tag[1] command to learn how to create and verify tag See the linkgit:git-tag[1] command to learn how to create and verify tag
objects. (Note that linkgit:git-tag[1] can also be used to create objects. (Note that linkgit:git-tag[1] can also be used to create
"lightweight tags", which are not tag objects at all, but just simple "lightweight tags", which are not tag objects at all, but just simple
references whose names begin with "refs/tags/"). references whose names begin with `refs/tags/`).
[[pack-files]] [[pack-files]]
How Git stores objects efficiently: pack files How Git stores objects efficiently: pack files
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Newly created objects are initially created in a file named after the Newly created objects are initially created in a file named after the
object's SHA-1 hash (stored in .git/objects). object's SHA-1 hash (stored in `.git/objects`).
Unfortunately this system becomes inefficient once a project has a Unfortunately this system becomes inefficient once a project has a
lot of objects. Try this on an old project: lot of objects. Try this on an old project:
@ -3208,9 +3209,9 @@ $ git prune
to remove any of the "loose" objects that are now contained in the to remove any of the "loose" objects that are now contained in the
pack. This will also remove any unreferenced objects (which may be pack. This will also remove any unreferenced objects (which may be
created when, for example, you use "git reset" to remove a commit). created when, for example, you use `git reset` to remove a commit).
You can verify that the loose objects are gone by looking at the You can verify that the loose objects are gone by looking at the
.git/objects directory or by running `.git/objects` directory or by running
------------------------------------------------ ------------------------------------------------
$ git count-objects $ git count-objects
@ -3237,7 +3238,7 @@ branch still exists, as does everything it pointed to. The branch
pointer itself just doesn't, since you replaced it with another one. pointer itself just doesn't, since you replaced it with another one.
There are also other situations that cause dangling objects. For There are also other situations that cause dangling objects. For
example, a "dangling blob" may arise because you did a "git add" of a example, a "dangling blob" may arise because you did a `git add` of a
file, but then, before you actually committed it and made it part of the file, but then, before you actually committed it and made it part of the
bigger picture, you changed something else in that file and committed bigger picture, you changed something else in that file and committed
that *updated* thing--the old state that you added originally ends up that *updated* thing--the old state that you added originally ends up
@ -3280,14 +3281,14 @@ $ git show <dangling-blob/tree-sha-goes-here>
------------------------------------------------ ------------------------------------------------
to show what the contents of the blob were (or, for a tree, basically to show what the contents of the blob were (or, for a tree, basically
what the "ls" for that directory was), and that may give you some idea what the `ls` for that directory was), and that may give you some idea
of what the operation was that left that dangling object. of what the operation was that left that dangling object.
Usually, dangling blobs and trees aren't very interesting. They're Usually, dangling blobs and trees aren't very interesting. They're
almost always the result of either being a half-way mergebase (the blob almost always the result of either being a half-way mergebase (the blob
will often even have the conflict markers from a merge in it, if you will often even have the conflict markers from a merge in it, if you
have had conflicting merges that you fixed up by hand), or simply have had conflicting merges that you fixed up by hand), or simply
because you interrupted a "git fetch" with ^C or something like that, because you interrupted a `git fetch` with ^C or something like that,
leaving _some_ of the new objects in the object database, but just leaving _some_ of the new objects in the object database, but just
dangling and useless. dangling and useless.
@ -3298,16 +3299,16 @@ state, you can just prune all unreachable objects:
$ git prune $ git prune
------------------------------------------------ ------------------------------------------------
and they'll be gone. But you should only run "git prune" on a quiescent and they'll be gone. But you should only run `git prune` on a quiescent
repository--it's kind of like doing a filesystem fsck recovery: you repository--it's kind of like doing a filesystem fsck recovery: you
don't want to do that while the filesystem is mounted. don't want to do that while the filesystem is mounted.
(The same is true of "git fsck" itself, btw, but since (The same is true of `git fsck` itself, btw, but since
`git fsck` never actually *changes* the repository, it just reports `git fsck` never actually *changes* the repository, it just reports
on what it found, `git fsck` itself is never 'dangerous' to run. on what it found, `git fsck` itself is never 'dangerous' to run.
Running it while somebody is actually changing the repository can cause Running it while somebody is actually changing the repository can cause
confusing and scary messages, but it won't actually do anything bad. In confusing and scary messages, but it won't actually do anything bad. In
contrast, running "git prune" while somebody is actively changing the contrast, running `git prune` while somebody is actively changing the
repository is a *BAD* idea). repository is a *BAD* idea).
[[recovering-from-repository-corruption]] [[recovering-from-repository-corruption]]
@ -3345,7 +3346,7 @@ missing blob 4b9458b3786228369c63936db65827de3cc06200
Now you know that blob 4b9458b3 is missing, and that the tree 2d9263c6 Now you know that blob 4b9458b3 is missing, and that the tree 2d9263c6
points to it. If you could find just one copy of that missing blob points to it. If you could find just one copy of that missing blob
object, possibly in some other repository, you could move it into object, possibly in some other repository, you could move it into
.git/objects/4b/9458b3... and be done. Suppose you can't. You can `.git/objects/4b/9458b3...` and be done. Suppose you can't. You can
still examine the tree that pointed to it with linkgit:git-ls-tree[1], still examine the tree that pointed to it with linkgit:git-ls-tree[1],
which might output something like: which might output something like:
@ -3360,10 +3361,10 @@ $ git ls-tree 2d9263c6d23595e7cb2a21e5ebbb53655278dff8
------------------------------------------------ ------------------------------------------------
So now you know that the missing blob was the data for a file named So now you know that the missing blob was the data for a file named
"myfile". And chances are you can also identify the directory--let's `myfile`. And chances are you can also identify the directory--let's
say it's in "somedirectory". If you're lucky the missing copy might be say it's in `somedirectory`. If you're lucky the missing copy might be
the same as the copy you have checked out in your working tree at the same as the copy you have checked out in your working tree at
"somedirectory/myfile"; you can test whether that's right with `somedirectory/myfile`; you can test whether that's right with
linkgit:git-hash-object[1]: linkgit:git-hash-object[1]:
------------------------------------------------ ------------------------------------------------
@ -3418,7 +3419,7 @@ $ git hash-object -w <recreated-file>
and your repository is good again! and your repository is good again!
(Btw, you could have ignored the fsck, and started with doing a (Btw, you could have ignored the `fsck`, and started with doing a
------------------------------------------------ ------------------------------------------------
$ git log --raw --all $ git log --raw --all
@ -3432,7 +3433,7 @@ just missing one particular blob version.
The index The index
----------- -----------
The index is a binary file (generally kept in .git/index) containing a The index is a binary file (generally kept in `.git/index`) containing a
sorted list of path names, each with permissions and the SHA-1 of a blob sorted list of path names, each with permissions and the SHA-1 of a blob
object; linkgit:git-ls-files[1] can show you the contents of the index: object; linkgit:git-ls-files[1] can show you the contents of the index:
@ -3572,7 +3573,7 @@ $ ls -a
The `git submodule add <repo> <path>` command does a couple of things: The `git submodule add <repo> <path>` command does a couple of things:
- It clones the submodule from <repo> to the given <path> under the - It clones the submodule from `<repo>` to the given `<path>` under the
current directory and by default checks out the master branch. current directory and by default checks out the master branch.
- It adds the submodule's clone path to the linkgit:gitmodules[5] file and - It adds the submodule's clone path to the linkgit:gitmodules[5] file and
adds this file to the index, ready to be committed. adds this file to the index, ready to be committed.
@ -3700,11 +3701,11 @@ Unable to checkout '261dfac35cb99d380eb966e102c1197139f7fa24' in submodule path
In older Git versions it could be easily forgotten to commit new or modified In older Git versions it could be easily forgotten to commit new or modified
files in a submodule, which silently leads to similar problems as not pushing files in a submodule, which silently leads to similar problems as not pushing
the submodule changes. Starting with Git 1.7.0 both "git status" and "git diff" the submodule changes. Starting with Git 1.7.0 both `git status` and `git diff`
in the superproject show submodules as modified when they contain new or in the superproject show submodules as modified when they contain new or
modified files to protect against accidentally committing such a state. "git modified files to protect against accidentally committing such a state. `git
diff" will also add a "-dirty" to the work tree side when generating patch diff` will also add a `-dirty` to the work tree side when generating patch
output or used with the --submodule option: output or used with the `--submodule` option:
------------------------------------------------- -------------------------------------------------
$ git diff $ git diff
@ -3880,7 +3881,7 @@ or, if you want to check out all of the index, use `-a`.
NOTE! `git checkout-index` normally refuses to overwrite old files, so NOTE! `git checkout-index` normally refuses to overwrite old files, so
if you have an old version of the tree already checked out, you will if you have an old version of the tree already checked out, you will
need to use the "-f" flag ('before' the "-a" flag or the filename) to need to use the `-f` flag ('before' the `-a` flag or the filename) to
'force' the checkout. 'force' the checkout.
@ -3891,7 +3892,7 @@ from one representation to the other:
Tying it all together Tying it all together
~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~
To commit a tree you have instantiated with "git write-tree", you'd To commit a tree you have instantiated with `git write-tree`, you'd
create a "commit" object that refers to that tree and the history create a "commit" object that refers to that tree and the history
behind it--most notably the "parent" commits that preceded it in behind it--most notably the "parent" commits that preceded it in
history. history.
@ -4152,8 +4153,9 @@ As a result, the general consistency of an object can always be tested
independently of the contents or the type of the object: all objects can independently of the contents or the type of the object: all objects can
be validated by verifying that (a) their hashes match the content of the be validated by verifying that (a) their hashes match the content of the
file and (b) the object successfully inflates to a stream of bytes that file and (b) the object successfully inflates to a stream of bytes that
forms a sequence of <ascii type without space> {plus} <space> {plus} <ascii decimal forms a sequence of
size> {plus} <byte\0> {plus} <binary object data>. `<ascii type without space> + <space> + <ascii decimal size> +
<byte\0> + <binary object data>`.
The structured objects can further have their structure and The structured objects can further have their structure and
connectivity to other objects verified. This is generally done with connectivity to other objects verified. This is generally done with
@ -4632,10 +4634,10 @@ Think about how to create a clear chapter dependency graph that will
allow people to get to important topics without necessarily reading allow people to get to important topics without necessarily reading
everything in between. everything in between.
Scan Documentation/ for other stuff left out; in particular: Scan `Documentation/` for other stuff left out; in particular:
- howto's - howto's
- some of technical/? - some of `technical/`?
- hooks - hooks
- list of commands in linkgit:git[1] - list of commands in linkgit:git[1]