Documentation / git-ls-files.txton commit Make GIT-VERSION-GEN tolerate missing git describe command again (374dfaa)
   1git-ls-files(1)
   2===============
   3
   4NAME
   5----
   6git-ls-files - Information about files in the index/working directory
   7
   8
   9SYNOPSIS
  10--------
  11'git-ls-files' [-z] [-t]
  12                (--[cached|deleted|others|ignored|stage|unmerged|killed|modified])\*
  13                (-[c|d|o|i|s|u|k|m])\*
  14                [-x <pattern>|--exclude=<pattern>]
  15                [-X <file>|--exclude-from=<file>]
  16                [--exclude-per-directory=<file>] 
  17                [--full-name] [--] [<file>]\*
  18
  19DESCRIPTION
  20-----------
  21This merges the file listing in the directory cache index with the
  22actual working directory list, and shows different combinations of the
  23two.
  24
  25One or more of the options below may be used to determine the files
  26shown:
  27
  28OPTIONS
  29-------
  30-c|--cached::
  31        Show cached files in the output (default)
  32
  33-d|--deleted::
  34        Show deleted files in the output
  35
  36-m|--modified::
  37        Show modified files in the output
  38
  39-o|--others::
  40        Show other files in the output
  41
  42-i|--ignored::
  43        Show ignored files in the output
  44        Note the this also reverses any exclude list present.
  45
  46-s|--stage::
  47        Show stage files in the output
  48
  49--directory::
  50        If a whole directory is classified as "other", show just its
  51        name (with a trailing slash) and not its whole contents.
  52
  53-u|--unmerged::
  54        Show unmerged files in the output (forces --stage)
  55
  56-k|--killed::
  57        Show files on the filesystem that need to be removed due
  58        to file/directory conflicts for checkout-index to
  59        succeed.
  60
  61-z::
  62        \0 line termination on output.
  63
  64-x|--exclude=<pattern>::
  65        Skips files matching pattern.
  66        Note that pattern is a shell wildcard pattern.
  67
  68-X|--exclude-from=<file>::
  69        exclude patterns are read from <file>; 1 per line.
  70
  71--exclude-per-directory=<file>::
  72        read additional exclude patterns that apply only to the
  73        directory and its subdirectories in <file>.
  74
  75-t::
  76        Identify the file status with the following tags (followed by
  77        a space) at the start of each line:
  78        H::     cached
  79        M::     unmerged
  80        R::     removed/deleted
  81        C::     modified/changed
  82        K::     to be killed
  83        ?       other
  84
  85--full-name::
  86        When run from a subdirectory, the command usually
  87        outputs paths relative to the current directory.  This
  88        option forces paths to be output relative to the project
  89        top directory.
  90
  91--::
  92        Do not interpret any more arguments as options.
  93
  94<file>::
  95        Files to show. If no files are given all files which match the other
  96        specified criteria are shown.
  97
  98Output
  99------
 100show files just outputs the filename unless '--stage' is specified in
 101which case it outputs:
 102
 103        [<tag> ]<mode> <object> <stage> <file>
 104
 105"git-ls-files --unmerged" and "git-ls-files --stage" can be used to examine
 106detailed information on unmerged paths.
 107
 108For an unmerged path, instead of recording a single mode/SHA1 pair,
 109the dircache records up to three such pairs; one from tree O in stage
 1101, A in stage 2, and B in stage 3.  This information can be used by
 111the user (or the porcelain) to see what should eventually be recorded at the
 112path. (see git-read-tree for more information on state)
 113
 114When `-z` option is not used, TAB, LF, and backslash characters
 115in pathnames are represented as `\t`, `\n`, and `\\`,
 116respectively.
 117
 118
 119Exclude Patterns
 120----------------
 121
 122'git-ls-files' can use a list of "exclude patterns" when
 123traversing the directory tree and finding files to show when the
 124flags --others or --ignored are specified.
 125
 126These exclude patterns come from these places:
 127
 128  1. command line flag --exclude=<pattern> specifies a single
 129     pattern.
 130
 131  2. command line flag --exclude-from=<file> specifies a list of
 132     patterns stored in a file.
 133
 134  3. command line flag --exclude-per-directory=<name> specifies
 135     a name of the file in each directory 'git-ls-files'
 136     examines, and if exists, its contents are used as an
 137     additional list of patterns.
 138
 139An exclude pattern file used by (2) and (3) contains one pattern
 140per line.  A line that starts with a '#' can be used as comment
 141for readability.
 142
 143There are three lists of patterns that are in effect at a given
 144time.  They are built and ordered in the following way:
 145
 146 * --exclude=<pattern> from the command line; patterns are
 147   ordered in the same order as they appear on the command line.
 148
 149 * lines read from --exclude-from=<file>; patterns are ordered
 150   in the same order as they appear in the file.
 151
 152 * When --exclude-per-directory=<name> is specified, upon
 153   entering a directory that has such a file, its contents are
 154   appended at the end of the current "list of patterns".  They
 155   are popped off when leaving the directory.
 156
 157Each pattern in the pattern list specifies "a match pattern" and
 158optionally the fate; either a file that matches the pattern is
 159considered excluded or included.  A filename is matched against
 160the patterns in the three lists; the --exclude-from list is
 161checked first, then the --exclude-per-directory list, and then
 162finally the --exclude list. The last match determines its fate.
 163If there is no match in the three lists, the fate is "included".
 164
 165A pattern specified on the command line with --exclude or read
 166from the file specified with --exclude-from is relative to the
 167top of the directory tree.  A pattern read from a file specified
 168by --exclude-per-directory is relative to the directory that the
 169pattern file appears in.
 170
 171An exclude pattern is of the following format:
 172
 173 - an optional prefix '!' which means that the fate this pattern
 174   specifies is "include", not the usual "exclude"; the
 175   remainder of the pattern string is interpreted according to
 176   the following rules.
 177
 178 - if it does not contain a slash '/', it is a shell glob
 179   pattern and used to match against the filename without
 180   leading directories (i.e. the same way as the current
 181   implementation).
 182
 183 - otherwise, it is a shell glob pattern, suitable for
 184   consumption by fnmatch(3) with FNM_PATHNAME flag.  I.e. a
 185   slash in the pattern must match a slash in the pathname.
 186   "Documentation/\*.html" matches "Documentation/git.html" but
 187   not "ppc/ppc.html".  As a natural exception, "/*.c" matches
 188   "cat-file.c" but not "mozilla-sha1/sha1.c".
 189
 190An example:
 191
 192--------------------------------------------------------------
 193    $ cat .git/ignore
 194    # ignore objects and archives, anywhere in the tree.
 195    *.[oa]
 196    $ cat Documentation/.gitignore
 197    # ignore generated html files,
 198    *.html
 199    # except foo.html which is maintained by hand
 200    !foo.html
 201    $ git-ls-files --ignored \
 202        --exclude='Documentation/*.[0-9]' \
 203        --exclude-from=.git/ignore \
 204        --exclude-per-directory=.gitignore
 205--------------------------------------------------------------
 206
 207
 208See Also
 209--------
 210gitlink:git-read-tree[1]
 211
 212
 213Author
 214------
 215Written by Linus Torvalds <torvalds@osdl.org>
 216
 217Documentation
 218--------------
 219Documentation by David Greaves, Junio C Hamano and the git-list <git@vger.kernel.org>.
 220
 221GIT
 222---
 223Part of the gitlink:git[7] suite
 224