blob: 6ffd896fbc78b783a7e00ed462f879cbff29d758 [file] [log] [blame]
Lars Hjemli70c7ac22007-05-26 15:56:40 +02001git-submodule(1)
2================
3
4NAME
5----
6git-submodule - Initialize, update or inspect submodules
7
8
9SYNOPSIS
10--------
Matt Kraaib2493642007-07-06 17:56:31 -070011[verse]
Steffen Prohaskac4a95c92008-01-21 07:41:27 +010012'git-submodule' [--quiet] add [-b branch] [--] <repository> [<path>]
13'git-submodule' [--quiet] status [--cached] [--] [<path>...]
14'git-submodule' [--quiet] [init|update] [--] [<path>...]
Ping Yin925e7f62008-03-11 21:52:18 +080015'git-submodule' [--quiet] summary [--summary-limit <n>] [commit] [--] [<path>...]
Lars Hjemli70c7ac22007-05-26 15:56:40 +020016
17
18COMMANDS
19--------
Sven Verdoolaegeecda0722007-06-24 23:06:07 +020020add::
21 Add the given repository as a submodule at the given path
Mark Levedahld4264ca2008-03-04 20:15:02 -050022 to the changeset to be committed next. If path is a valid
23 repository within the project, it is added as is. Otherwise,
24 repository is cloned at the specified path. path is added to the
Sven Verdoolaegeecda0722007-06-24 23:06:07 +020025 changeset and registered in .gitmodules. If no path is
26 specified, the path is deduced from the repository specification.
Mark Levedahlf31a5222007-09-23 22:19:42 -040027 If the repository url begins with ./ or ../, it is stored as
28 given but resolved as a relative path from the main project's
29 url when cloning.
Sven Verdoolaegeecda0722007-06-24 23:06:07 +020030
Lars Hjemli70c7ac22007-05-26 15:56:40 +020031status::
32 Show the status of the submodules. This will print the SHA-1 of the
33 currently checked out commit for each submodule, along with the
Dan McGee5162e692007-12-29 00:20:38 -060034 submodule path and the output of linkgit:git-describe[1] for the
Lars Hjemli70c7ac22007-05-26 15:56:40 +020035 SHA-1. Each SHA-1 will be prefixed with `-` if the submodule is not
36 initialized and `+` if the currently checked out submodule commit
37 does not match the SHA-1 found in the index of the containing
38 repository. This command is the default command for git-submodule.
39
40init::
Lars Hjemli211b7f12007-06-06 11:13:02 +020041 Initialize the submodules, i.e. register in .git/config each submodule
Lars Hjemli813a0bd2007-07-06 19:38:38 +020042 name and url found in .gitmodules. The key used in .git/config is
43 `submodule.$name.url`. This command does not alter existing information
Lars Hjemli211b7f12007-06-06 11:13:02 +020044 in .git/config.
Lars Hjemli70c7ac22007-05-26 15:56:40 +020045
46update::
Lars Hjemli211b7f12007-06-06 11:13:02 +020047 Update the registered submodules, i.e. clone missing submodules and
48 checkout the commit specified in the index of the containing repository.
49 This will make the submodules HEAD be detached.
Lars Hjemli70c7ac22007-05-26 15:56:40 +020050
Ping Yin925e7f62008-03-11 21:52:18 +080051summary::
52 Show commit summary between the given commit (defaults to HEAD) and
53 working tree/index. For a submodule in question, a series of commits
54 in the submodule between the given super project commit and the
55 index or working tree (switched by --cached) are shown.
Lars Hjemli70c7ac22007-05-26 15:56:40 +020056
57OPTIONS
58-------
59-q, --quiet::
60 Only print error messages.
61
Sven Verdoolaegeecda0722007-06-24 23:06:07 +020062-b, --branch::
63 Branch of repository to add as submodule.
64
Lars Hjemli70c7ac22007-05-26 15:56:40 +020065--cached::
Ping Yin925e7f62008-03-11 21:52:18 +080066 This option is only valid for status and summary commands. These
67 commands typically use the commit found in the submodule HEAD, but
68 with this option, the commit stored in the index is used instead.
69
70-n, --summary-limit::
71 This option is only valid for the summary command.
72 Limit the summary size (number of commits shown in total).
Junio C Hamano51836e92008-04-12 18:34:39 -070073 Giving 0 will disable the summary; a negative number means unlimited
Ping Yin925e7f62008-03-11 21:52:18 +080074 (the default). This limit only applies to modified submodules. The
75 size is always limited to 1 for added/deleted/typechanged submodules.
Lars Hjemli70c7ac22007-05-26 15:56:40 +020076
77<path>::
78 Path to submodule(s). When specified this will restrict the command
79 to only operate on the submodules found at the specified paths.
80
81FILES
82-----
Lars Hjemli211b7f12007-06-06 11:13:02 +020083When initializing submodules, a .gitmodules file in the top-level directory
Lars Hjemli70c7ac22007-05-26 15:56:40 +020084of the containing repository is used to find the url of each submodule.
Junio C Hamanoc4585702007-12-27 23:29:53 -080085This file should be formatted in the same way as `$GIT_DIR/config`. The key
Dan McGee5162e692007-12-29 00:20:38 -060086to each submodule url is "submodule.$name.url". See linkgit:gitmodules[5]
Junio C Hamano6fbe42c2007-12-16 22:03:21 -080087for details.
Lars Hjemli70c7ac22007-05-26 15:56:40 +020088
89
90AUTHOR
91------
92Written by Lars Hjemli <hjemli@gmail.com>
93
94GIT
95---
Dan McGee5162e692007-12-29 00:20:38 -060096Part of the linkgit:git[7] suite