@ -63,14 +63,6 @@ add [-b <branch>] [-f|--force] [--name <name>] [--reference <repository>] [--dep
to the changeset to be committed next to the current
to the changeset to be committed next to the current
project: the current project is termed the "superproject".
project: the current project is termed the "superproject".
+
+
This requires at least one argument: <repository>. The optional
argument <path> is the relative location for the cloned submodule
to exist in the superproject. If <path> is not given, the
"humanish" part of the source repository is used ("repo" for
"/path/to/repo.git" and "foo" for "host.xz:foo/.git").
The <path> is also used as the submodule's logical name in its
configuration entries unless `--name` is used to specify a logical name.
+
<repository> is the URL of the new submodule's origin repository.
<repository> is the URL of the new submodule's origin repository.
This may be either an absolute URL, or (if it begins with ./
This may be either an absolute URL, or (if it begins with ./
or ../), the location relative to the superproject's default remote
or ../), the location relative to the superproject's default remote
@ -87,21 +79,22 @@ If the superproject doesn't have a default remote configured
the superproject is its own authoritative upstream and the current
the superproject is its own authoritative upstream and the current
working directory is used instead.
working directory is used instead.
+
+
<path> is the relative location for the cloned submodule to
The optional argument <path> is the relative location for the cloned
exist in the superproject. If <path> does not exist, then the
submodule to exist in the superproject. If <path> is not given, the
submodule is created by cloning from the named URL. If <path> does
canonical part of the source repository is used ("repo" for
exist and is already a valid Git repository, then this is added
"/path/to/repo.git" and "foo" for "host.xz:foo/.git"). If <path>
to the changeset without cloning. This second form is provided
exists and is already a valid Git repository, then it is staged
to ease creating a new submodule from scratch, and presumes
for commit without cloning. The <path> is also used as the submodule's
the user will later push the submodule to the given URL.
logical name in its configuration entries unless `--name` is used
to specify a logical name.
+
+
In either case, the given URL is recorded into .gitmodules for
The given URL is recorded into `.gitmodules` for use by subsequent users
use by subsequent users cloning the superproject. If the URL is
cloning the superproject. If the URL is given relative to the
given relative to the superproject's repository, the presumption
superproject's repository, the presumption is the superproject and
is the superproject and submodule repositories will be kept
submodule repositories will be kept together in the same relative
together in the same relative location, and only the
location, and only the superproject's URL needs to be provided.
superproject's URL needs to be provided: git-submodule will correctly
git-submodule will correctly locate the submodule using the relative
locate the submodule using the relative URL in .gitmodules.
URL in `.gitmodules`.
status [--cached] [--recursive] [--] [<path>...]::
status [--cached] [--recursive] [--] [<path>...]::
Show the status of the submodules. This will print the SHA-1 of the
Show the status of the submodules. This will print the SHA-1 of the
@ -123,7 +116,7 @@ too (and can also report changes to a submodule's work tree).
init [--] [<path>...]::
init [--] [<path>...]::
Initialize the submodules recorded in the index (which were
Initialize the submodules recorded in the index (which were
added and committed elsewhere) by setting `submodule.$name.url`
added and committed elsewhere) by setting `submodule.$name.url`
in .git/config. It uses the same setting from .gitmodules as
in .git/config. It uses the same setting from `.gitmodules` as
a template. If the URL is relative, it will be resolved using
a template. If the URL is relative, it will be resolved using
the default remote. If there is no default remote, the current
the default remote. If there is no default remote, the current
repository will be assumed to be upstream.
repository will be assumed to be upstream.
@ -197,7 +190,7 @@ configuration variable:
none;; the submodule is not updated.
none;; the submodule is not updated.
If the submodule is not yet initialized, and you just want to use the
If the submodule is not yet initialized, and you just want to use the
setting as stored in .gitmodules, you can automatically initialize the
setting as stored in `.gitmodules`, you can automatically initialize the
submodule with the `--init` option.
submodule with the `--init` option.
If `--recursive` is specified, this command will recurse into the
If `--recursive` is specified, this command will recurse into the
@ -220,7 +213,7 @@ foreach [--recursive] <command>::
Evaluates an arbitrary shell command in each checked out submodule.
Evaluates an arbitrary shell command in each checked out submodule.
The command has access to the variables $name, $path, $sha1 and
The command has access to the variables $name, $path, $sha1 and
$toplevel:
$toplevel:
$name is the name of the relevant submodule section in .gitmodules,
$name is the name of the relevant submodule section in `.gitmodules`,
$path is the name of the submodule directory relative to the
$path is the name of the submodule directory relative to the
superproject, $sha1 is the commit as recorded in the superproject,
superproject, $sha1 is the commit as recorded in the superproject,
and $toplevel is the absolute path to the top-level of the superproject.
and $toplevel is the absolute path to the top-level of the superproject.
@ -242,7 +235,7 @@ git submodule foreach 'echo $path `git rev-parse HEAD`'
sync [--recursive] [--] [<path>...]::
sync [--recursive] [--] [<path>...]::
Synchronizes submodules' remote URL configuration setting
Synchronizes submodules' remote URL configuration setting
to the value specified in .gitmodules. It will only affect those
to the value specified in `.gitmodules`. It will only affect those
submodules which already have a URL entry in .git/config (that is the
submodules which already have a URL entry in .git/config (that is the
case when they are initialized or freshly added). This is useful when
case when they are initialized or freshly added). This is useful when
submodule URLs change upstream and you need to update your local
submodule URLs change upstream and you need to update your local
@ -413,7 +406,7 @@ for linkgit:git-clone[1]'s `--reference` and `--shared` options carefully.
--[no-]recommend-shallow::
--[no-]recommend-shallow::
This option is only valid for the update command.
This option is only valid for the update command.
The initial clone of a submodule will use the recommended
The initial clone of a submodule will use the recommended
`submodule.<name>.shallow` as provided by the .gitmodules file
`submodule.<name>.shallow` as provided by the `.gitmodules` file
by default. To ignore the suggestions use `--no-recommend-shallow`.
by default. To ignore the suggestions use `--no-recommend-shallow`.
-j <n>::
-j <n>::
@ -429,7 +422,7 @@ for linkgit:git-clone[1]'s `--reference` and `--shared` options carefully.
FILES
FILES
-----
-----
When initializing submodules, a .gitmodules file in the top-level directory
When initializing submodules, a `.gitmodules` file in the top-level directory
of the containing repository is used to find the url of each submodule.
of the containing repository is used to find the url of each submodule.
This file should be formatted in the same way as `$GIT_DIR/config`. The key
This file should be formatted in the same way as `$GIT_DIR/config`. The key
to each submodule url is "submodule.$name.url". See linkgit:gitmodules[5]
to each submodule url is "submodule.$name.url". See linkgit:gitmodules[5]