blob: d70abc6afe3aa40aaaab2e055ee75d8ee22cdb69 [file] [log] [blame]
Junio C Hamano1a4e8412005-12-27 08:17:231git-status(1)
2=============
3
4NAME
5----
Junio C Hamano7c73c662007-01-19 00:37:506git-status - Show the working tree status
Junio C Hamano1a4e8412005-12-27 08:17:237
8
9SYNOPSIS
10--------
Junio C Hamano15567bc2011-07-23 00:51:5911[verse]
Junio C Hamanoa0fae262009-12-28 09:33:5012'git status' [<options>...] [--] [<pathspec>...]
Junio C Hamano1a4e8412005-12-27 08:17:2313
14DESCRIPTION
15-----------
Junio C Hamano942b35e2007-12-09 10:19:3316Displays paths that have differences between the index file and the
17current HEAD commit, paths that have differences between the working
18tree and the index file, and paths in the working tree that are not
Junio C Hamano076ffcc2013-02-06 05:13:2119tracked by Git (and are not ignored by linkgit:gitignore[5]). The first
Junio C Hamano942b35e2007-12-09 10:19:3320are what you _would_ commit by running `git commit`; the second and
Junio C Hamano1aa40d22010-01-21 17:46:4321third are what you _could_ commit by running 'git add' before running
Junio C Hamano942b35e2007-12-09 10:19:3322`git commit`.
Junio C Hamano1a4e8412005-12-27 08:17:2323
Junio C Hamanoa0fae262009-12-28 09:33:5024OPTIONS
25-------
Junio C Hamano8fd52302006-08-10 00:18:0826
Junio C Hamanoa0fae262009-12-28 09:33:5027-s::
28--short::
29Give the output in the short-format.
30
Junio C Hamanof5de4cf2010-06-19 00:33:1731-b::
32--branch::
33Show the branch and tracking info even in short-format.
34
Junio C Hamanocd451662016-09-13 00:54:0935--porcelain[=<version>]::
Junio C Hamanoef5a2f92011-05-31 19:53:3336Give the output in an easy-to-parse format for scripts.
37This is similar to the short output, but will remain stable
Junio C Hamano076ffcc2013-02-06 05:13:2138across Git versions and regardless of user configuration. See
Junio C Hamanoef5a2f92011-05-31 19:53:3339below for details.
Junio C Hamanocd451662016-09-13 00:54:0940+
41The version parameter is used to specify the format version.
42This is optional and defaults to the original version 'v1' format.
Junio C Hamanoa0fae262009-12-28 09:33:5043
Junio C Hamanoa1295452012-11-13 22:32:0444--long::
45Give the output in the long-format. This is the default.
46
Junio C Hamano8152abf2015-04-28 22:48:0247-v::
48--verbose::
49In addition to the names of files that have been changed, also
50show the textual changes that are staged to be committed
51(i.e., like the output of `git diff --cached`). If `-v` is specified
52twice, then also show the changes in the working tree that
53have not yet been staged (i.e., like the output of `git diff`).
54
Junio C Hamanoa0fae262009-12-28 09:33:5055-u[<mode>]::
56--untracked-files[=<mode>]::
Junio C Hamano36a4dbc2011-02-22 07:51:3257Show untracked files.
Junio C Hamanoa0fae262009-12-28 09:33:5058+
Junio C Hamano1eb56092015-10-05 20:39:5359The mode parameter is used to specify the handling of untracked files.
60It is optional: it defaults to 'all', and if specified, it must be
61stuck to the option (e.g. `-uno`, but not `-u no`).
Junio C Hamanoa0fae262009-12-28 09:33:5062+
Junio C Hamano36a4dbc2011-02-22 07:51:3263The possible options are:
64+
Junio C Hamano5e7f1312013-03-21 22:49:0165- 'no' - Show no untracked files.
66- 'normal' - Shows untracked files and directories.
Junio C Hamanoa0fae262009-12-28 09:33:5067- 'all' - Also shows individual files in untracked directories.
Junio C Hamanoa0fae262009-12-28 09:33:5068+
Junio C Hamano5e7f1312013-03-21 22:49:0169When `-u` option is not used, untracked files and directories are
70shown (i.e. the same as specifying `normal`), to help you avoid
71forgetting to add newly created files. Because it takes extra work
72to find untracked files in the filesystem, this mode may take some
Junio C Hamanoc4e2a202015-05-26 21:38:4773time in a large working tree.
74Consider enabling untracked cache and split index if supported (see
75`git update-index --untracked-cache` and `git update-index
76--split-index`), Otherwise you can use `no` to have `git status`
Junio C Hamano5e7f1312013-03-21 22:49:0177return more quickly without showing untracked files.
78+
Junio C Hamano36a4dbc2011-02-22 07:51:3279The default can be changed using the status.showUntrackedFiles
80configuration variable documented in linkgit:git-config[1].
Junio C Hamanoa0fae262009-12-28 09:33:5081
Junio C Hamano7d449522010-07-01 00:08:5182--ignore-submodules[=<when>]::
83Ignore changes to submodules when looking for changes. <when> can be
Junio C Hamano619596a2010-08-18 22:15:3584either "none", "untracked", "dirty" or "all", which is the default.
85Using "none" will consider the submodule modified when it either contains
86untracked or modified files or its HEAD differs from the commit recorded
87in the superproject and can be used to override any settings of the
88'ignore' option in linkgit:git-config[1] or linkgit:gitmodules[5]. When
Junio C Hamano7d449522010-07-01 00:08:5189"untracked" is used submodules are not considered dirty when they only
90contain untracked content (but they are still scanned for modified
91content). Using "dirty" ignores all changes to the work tree of submodules,
92only changes to the commits stored in the superproject are shown (this was
93the behavior before 1.7.0). Using "all" hides all changes to submodules
94(and suppresses the output of submodule summaries when the config option
Junio C Hamano322c6242015-03-23 21:32:4695`status.submoduleSummary` is set).
Junio C Hamano7d449522010-07-01 00:08:5196
Junio C Hamano4c4b0122011-06-30 01:19:3297--ignored::
98Show ignored files as well.
99
Junio C Hamanoa0fae262009-12-28 09:33:50100-z::
101Terminate entries with NUL, instead of LF. This implies
Junio C Hamanocd451662016-09-13 00:54:09102the `--porcelain=v1` output format if no other format is given.
Junio C Hamano942b35e2007-12-09 10:19:33103
Junio C Hamano22700fb2012-05-03 23:07:25104--column[=<options>]::
105--no-column::
106Display untracked files in columns. See configuration variable
107column.status for option syntax.`--column` and `--no-column`
108without options are equivalent to 'always' and 'never'
109respectively.
110
Junio C Hamano1a4e8412005-12-27 08:17:23111
112OUTPUT
113------
114The output from this command is designed to be used as a commit
Junio C Hamano52b6ba32014-04-01 00:26:48115template comment.
Junio C Hamanoa0fae262009-12-28 09:33:50116The default, long format, is designed to be human readable,
Junio C Hamanoef5a2f92011-05-31 19:53:33117verbose and descriptive. Its contents and format are subject to change
118at any time.
Junio C Hamano1a4e8412005-12-27 08:17:23119
Junio C Hamano076ffcc2013-02-06 05:13:21120The paths mentioned in the output, unlike many other Git commands, are
Junio C Hamano942b35e2007-12-09 10:19:33121made relative to the current directory if you are working in a
122subdirectory (this is on purpose, to help cutting and pasting). See
123the status.relativePaths config option below.
Junio C Hamano00b8b632007-12-07 09:50:49124
Junio C Hamanoef5a2f92011-05-31 19:53:33125Short Format
126~~~~~~~~~~~~
127
128In the short-format, the status of each path is shown as
Junio C Hamanoa0fae262009-12-28 09:33:50129
130XY PATH1 -> PATH2
131
Junio C Hamanob76a6862012-05-02 22:02:46132where `PATH1` is the path in the `HEAD`, and the " `-> PATH2`" part is
Junio C Hamanoa0fae262009-12-28 09:33:50133shown only when `PATH1` corresponds to a different path in the
Junio C Hamanod2c28482014-10-24 22:28:25134index/worktree (i.e. the file is renamed). The `XY` is a two-letter
Junio C Hamanofc5d7352010-04-24 02:59:11135status code.
Junio C Hamanoa0fae262009-12-28 09:33:50136
Junio C Hamanob76a6862012-05-02 22:02:46137The fields (including the `->`) are separated from each other by a
Junio C Hamanofc5d7352010-04-24 02:59:11138single space. If a filename contains whitespace or other nonprintable
139characters, that field will be quoted in the manner of a C string
140literal: surrounded by ASCII double quote (34) characters, and with
141interior special characters backslash-escaped.
Junio C Hamanoa0fae262009-12-28 09:33:50142
Junio C Hamanod2c28482014-10-24 22:28:25143For paths with merge conflicts, `X` and `Y` show the modification
Junio C Hamanofc5d7352010-04-24 02:59:11144states of each side of the merge. For paths that do not have merge
145conflicts, `X` shows the status of the index, and `Y` shows the status
146of the work tree. For untracked paths, `XY` are `??`. Other status
147codes can be interpreted as follows:
148
149* ' ' = unmodified
150* 'M' = modified
151* 'A' = added
152* 'D' = deleted
153* 'R' = renamed
154* 'C' = copied
155* 'U' = updated but unmerged
156
Junio C Hamano4c4b0122011-06-30 01:19:32157Ignored files are not listed, unless `--ignored` option is in effect,
158in which case `XY` are `!!`.
Junio C Hamanoa0fae262009-12-28 09:33:50159
160 X Y Meaning
161 -------------------------------------------------
162 [MD] not updated
163 M [ MD] updated in index
164 A [ MD] added to index
Junio C Hamanofc5d7352010-04-24 02:59:11165 D [ M] deleted from index
Junio C Hamanoa0fae262009-12-28 09:33:50166 R [ MD] renamed in index
167 C [ MD] copied in index
168 [MARC] index and work tree matches
169 [ MARC] M work tree changed since index
170 [ MARC] D deleted in work tree
171 -------------------------------------------------
172 D D unmerged, both deleted
173 A U unmerged, added by us
174 U D unmerged, deleted by them
175 U A unmerged, added by them
176 D U unmerged, deleted by us
177 A A unmerged, both added
178 U U unmerged, both modified
179 -------------------------------------------------
180 ? ? untracked
Junio C Hamano4c4b0122011-06-30 01:19:32181 ! ! ignored
Junio C Hamanoa0fae262009-12-28 09:33:50182 -------------------------------------------------
183
Junio C Hamano52a094d2017-04-20 05:35:10184Submodules have more state and instead report
185M the submodule has a different HEAD than
186 recorded in the index
187m the submodule has modified content
188? the submodule has untracked files
189since modified content or untracked files in a submodule cannot be added
190via `git add` in the superproject to prepare a commit.
191
192'm' and '?' are applied recursively. For example if a nested submodule
193in a submodule contains an untracked file, this is reported as '?' as well.
194
Junio C Hamanof5de4cf2010-06-19 00:33:17195If -b is used the short-format status is preceded by a line
196
Junio C Hamanocd451662016-09-13 00:54:09197 ## branchname tracking info
Junio C Hamanof5de4cf2010-06-19 00:33:17198
Junio C Hamanocd451662016-09-13 00:54:09199Porcelain Format Version 1
200~~~~~~~~~~~~~~~~~~~~~~~~~~
Junio C Hamanoef5a2f92011-05-31 19:53:33201
Junio C Hamanocd451662016-09-13 00:54:09202Version 1 porcelain format is similar to the short format, but is guaranteed
Junio C Hamano076ffcc2013-02-06 05:13:21203not to change in a backwards-incompatible way between Git versions or
Junio C Hamanoef5a2f92011-05-31 19:53:33204based on user configuration. This makes it ideal for parsing by scripts.
205The description of the short format above also describes the porcelain
206format, with a few exceptions:
207
2081. The user's color.status configuration is not respected; color will
209 always be off.
210
2112. The user's status.relativePaths configuration is not respected; paths
212 shown will always be relative to the repository root.
213
214There is also an alternate -z format recommended for machine parsing. In
Junio C Hamanofc5d7352010-04-24 02:59:11215that format, the status field is the same, but some other things
Junio C Hamanoef5a2f92011-05-31 19:53:33216change. First, the '\->' is omitted from rename entries and the field
217order is reversed (e.g 'from \-> to' becomes 'to from'). Second, a NUL
Junio C Hamanofc5d7352010-04-24 02:59:11218(ASCII 0) follows each filename, replacing space as a field separator
219and the terminating newline (but a space still separates the status
220field from the first filename). Third, filenames containing special
221characters are not specially formatted; no quoting or
Junio C Hamanobcdb12e2012-05-10 18:45:15222backslash-escaping is performed.
Junio C Hamano1a4e8412005-12-27 08:17:23223
Junio C Hamano52a094d2017-04-20 05:35:10224Any submodule changes are reported as modified `M` instead of `m` or single `?`.
225
Junio C Hamanocd451662016-09-13 00:54:09226Porcelain Format Version 2
227~~~~~~~~~~~~~~~~~~~~~~~~~~
228
229Version 2 format adds more detailed information about the state of
230the worktree and changed items. Version 2 also defines an extensible
231set of easy to parse optional headers.
232
233Header lines start with "#" and are added in response to specific
234command line arguments. Parsers should ignore headers they
235don't recognize.
236
237### Branch Headers
238
239If `--branch` is given, a series of header lines are printed with
240information about the current branch.
241
242 Line Notes
243 ------------------------------------------------------------
244 # branch.oid <commit> | (initial) Current commit.
245 # branch.head <branch> | (detached) Current branch.
246 # branch.upstream <upstream_branch> If upstream is set.
247 # branch.ab +<ahead> -<behind> If upstream is set and
248 the commit is present.
249 ------------------------------------------------------------
250
251### Changed Tracked Entries
252
253Following the headers, a series of lines are printed for tracked
254entries. One of three different line formats may be used to describe
255an entry depending on the type of change. Tracked entries are printed
256in an undefined order; parsers should allow for a mixture of the 3
257line types in any order.
258
259Ordinary changed entries have the following format:
260
261 1 <XY> <sub> <mH> <mI> <mW> <hH> <hI> <path>
262
263Renamed or copied entries have the following format:
264
265 2 <XY> <sub> <mH> <mI> <mW> <hH> <hI> <X><score> <path><sep><origPath>
266
267 Field Meaning
268 --------------------------------------------------------
269 <XY> A 2 character field containing the staged and
270unstaged XY values described in the short format,
271with unchanged indicated by a "." rather than
272a space.
273 <sub> A 4 character field describing the submodule state.
274"N..." when the entry is not a submodule.
275"S<c><m><u>" when the entry is a submodule.
276<c> is "C" if the commit changed; otherwise ".".
277<m> is "M" if it has tracked changes; otherwise ".".
278<u> is "U" if there are untracked changes; otherwise ".".
279 <mH> The octal file mode in HEAD.
280 <mI> The octal file mode in the index.
281 <mW> The octal file mode in the worktree.
282 <hH> The object name in HEAD.
283 <hI> The object name in the index.
284 <X><score> The rename or copy score (denoting the percentage
285of similarity between the source and target of the
286move or copy). For example "R100" or "C75".
287 <path> The pathname. In a renamed/copied entry, this
288is the path in the index and in the working tree.
289 <sep> When the `-z` option is used, the 2 pathnames are separated
290with a NUL (ASCII 0x00) byte; otherwise, a tab (ASCII 0x09)
291byte separates them.
292 <origPath> The pathname in the commit at HEAD. This is only
293present in a renamed/copied entry, and tells
294where the renamed/copied contents came from.
295 --------------------------------------------------------
296
297Unmerged entries have the following format; the first character is
298a "u" to distinguish from ordinary changed entries.
299
300 u <xy> <sub> <m1> <m2> <m3> <mW> <h1> <h2> <h3> <path>
301
302 Field Meaning
303 --------------------------------------------------------
304 <XY> A 2 character field describing the conflict type
305as described in the short format.
306 <sub> A 4 character field describing the submodule state
307as described above.
308 <m1> The octal file mode in stage 1.
309 <m2> The octal file mode in stage 2.
310 <m3> The octal file mode in stage 3.
311 <mW> The octal file mode in the worktree.
312 <h1> The object name in stage 1.
313 <h2> The object name in stage 2.
314 <h3> The object name in stage 3.
315 <path> The pathname.
316 --------------------------------------------------------
317
318### Other Items
319
320Following the tracked entries (and if requested), a series of
321lines will be printed for untracked and then ignored items
322found in the worktree.
323
324Untracked items have the following format:
325
326 ? <path>
327
328Ignored items have the following format:
329
330 ! <path>
331
332### Pathname Format Notes and -z
333
334When the `-z` option is given, pathnames are printed as is and
335without any quoting and lines are terminated with a NUL (ASCII 0x00)
336byte.
337
Junio C Hamano0f6f3bf2017-03-13 07:01:53338Without the `-z` option, pathnames with "unusual" characters are
339quoted as explained for the configuration variable `core.quotePath`
340(see linkgit:git-config[1]).
Junio C Hamanocd451662016-09-13 00:54:09341
342
Junio C Hamanof9771f62007-01-17 17:42:30343CONFIGURATION
344-------------
345
346The command honors `color.status` (or `status.color` -- they
347mean the same thing and the latter is kept for backward
348compatibility) and `color.status.<slot>` configuration variables
349to colorize its output.
350
Junio C Hamano942b35e2007-12-09 10:19:33351If the config variable `status.relativePaths` is set to false, then all
352paths shown are relative to the repository root, not to the current
353directory.
354
Junio C Hamano322c6242015-03-23 21:32:46355If `status.submoduleSummary` is set to a non zero number or true (identical
Junio C Hamanoa0fae262009-12-28 09:33:50356to -1 or an unlimited number), the submodule summary will be enabled for
357the long format and a summary of commits for modified submodules will be
Junio C Hamano369e3402013-10-15 18:40:25358shown (see --summary-limit option of linkgit:git-submodule[1]). Please note
359that the summary output from the status command will be suppressed for all
360submodules when `diff.ignoreSubmodules` is set to 'all' or only for those
361submodules where `submodule.<name>.ignore=all`. To also view the summary for
362ignored submodules you can either use the --ignore-submodules=dirty command
363line option or the 'git submodule summary' command, which shows a similar
364output but does not honor these settings.
Junio C Hamanoe3ddb5b2008-04-21 00:48:07365
Junio C Hamano9049d912008-05-29 02:09:50366SEE ALSO
Junio C Hamano679d22d2007-06-02 21:13:44367--------
Junio C Hamano35738e82008-01-07 07:55:46368linkgit:gitignore[5]
Junio C Hamanof9771f62007-01-17 17:42:30369
Junio C Hamano1a4e8412005-12-27 08:17:23370GIT
371---
Junio C Hamanof7c042d2008-06-06 22:50:53372Part of the linkgit:git[1] suite