|  | git-ls-files(1) | 
|  | =============== | 
|  |  | 
|  | NAME | 
|  | ---- | 
|  | git-ls-files - Show information about files in the index and the working tree | 
|  |  | 
|  |  | 
|  | SYNOPSIS | 
|  | -------- | 
|  | [verse] | 
|  | 'git ls-files' [-z] [-t] [-v] [-f] | 
|  | (--[cached|deleted|others|ignored|stage|unmerged|killed|modified])* | 
|  | (-[c|d|o|i|s|u|k|m])* | 
|  | [--eol] | 
|  | [-x <pattern>|--exclude=<pattern>] | 
|  | [-X <file>|--exclude-from=<file>] | 
|  | [--exclude-per-directory=<file>] | 
|  | [--exclude-standard] | 
|  | [--error-unmatch] [--with-tree=<tree-ish>] | 
|  | [--full-name] [--recurse-submodules] | 
|  | [--abbrev] [--] [<file>...] | 
|  |  | 
|  | DESCRIPTION | 
|  | ----------- | 
|  | This merges the file listing in the directory cache index with the | 
|  | actual working directory list, and shows different combinations of the | 
|  | two. | 
|  |  | 
|  | One or more of the options below may be used to determine the files | 
|  | shown: | 
|  |  | 
|  | OPTIONS | 
|  | ------- | 
|  | -c:: | 
|  | --cached:: | 
|  | Show cached files in the output (default) | 
|  |  | 
|  | -d:: | 
|  | --deleted:: | 
|  | Show deleted files in the output | 
|  |  | 
|  | -m:: | 
|  | --modified:: | 
|  | Show modified files in the output | 
|  |  | 
|  | -o:: | 
|  | --others:: | 
|  | Show other (i.e. untracked) files in the output | 
|  |  | 
|  | -i:: | 
|  | --ignored:: | 
|  | Show only ignored files in the output. When showing files in the | 
|  | index, print only those matched by an exclude pattern. When | 
|  | showing "other" files, show only those matched by an exclude | 
|  | pattern. Standard ignore rules are not automatically activated, | 
|  | therefore at least one of the `--exclude*` options is required. | 
|  |  | 
|  | -s:: | 
|  | --stage:: | 
|  | Show staged contents' mode bits, object name and stage number in the output. | 
|  |  | 
|  | --directory:: | 
|  | If a whole directory is classified as "other", show just its | 
|  | name (with a trailing slash) and not its whole contents. | 
|  |  | 
|  | --no-empty-directory:: | 
|  | Do not list empty directories. Has no effect without --directory. | 
|  |  | 
|  | -u:: | 
|  | --unmerged:: | 
|  | Show unmerged files in the output (forces --stage) | 
|  |  | 
|  | -k:: | 
|  | --killed:: | 
|  | Show files on the filesystem that need to be removed due | 
|  | to file/directory conflicts for checkout-index to | 
|  | succeed. | 
|  |  | 
|  | -z:: | 
|  | \0 line termination on output and do not quote filenames. | 
|  | See OUTPUT below for more information. | 
|  |  | 
|  | -x <pattern>:: | 
|  | --exclude=<pattern>:: | 
|  | Skip untracked files matching pattern. | 
|  | Note that pattern is a shell wildcard pattern. See EXCLUDE PATTERNS | 
|  | below for more information. | 
|  |  | 
|  | -X <file>:: | 
|  | --exclude-from=<file>:: | 
|  | Read exclude patterns from <file>; 1 per line. | 
|  |  | 
|  | --exclude-per-directory=<file>:: | 
|  | Read additional exclude patterns that apply only to the | 
|  | directory and its subdirectories in <file>. | 
|  |  | 
|  | --exclude-standard:: | 
|  | Add the standard Git exclusions: .git/info/exclude, .gitignore | 
|  | in each directory, and the user's global exclusion file. | 
|  |  | 
|  | --error-unmatch:: | 
|  | If any <file> does not appear in the index, treat this as an | 
|  | error (return 1). | 
|  |  | 
|  | --with-tree=<tree-ish>:: | 
|  | When using --error-unmatch to expand the user supplied | 
|  | <file> (i.e. path pattern) arguments to paths, pretend | 
|  | that paths which were removed in the index since the | 
|  | named <tree-ish> are still present.  Using this option | 
|  | with `-s` or `-u` options does not make any sense. | 
|  |  | 
|  | -t:: | 
|  | This feature is semi-deprecated. For scripting purpose, | 
|  | linkgit:git-status[1] `--porcelain` and | 
|  | linkgit:git-diff-files[1] `--name-status` are almost always | 
|  | superior alternatives, and users should look at | 
|  | linkgit:git-status[1] `--short` or linkgit:git-diff[1] | 
|  | `--name-status` for more user-friendly alternatives. | 
|  | + | 
|  | -- | 
|  | This option identifies the file status with the following tags (followed by | 
|  | a space) at the start of each line: | 
|  |  | 
|  | H::	cached | 
|  | S::	skip-worktree | 
|  | M::	unmerged | 
|  | R::	removed/deleted | 
|  | C::	modified/changed | 
|  | K::	to be killed | 
|  | ?::	other | 
|  | -- | 
|  |  | 
|  | -v:: | 
|  | Similar to `-t`, but use lowercase letters for files | 
|  | that are marked as 'assume unchanged' (see | 
|  | linkgit:git-update-index[1]). | 
|  |  | 
|  | -f:: | 
|  | Similar to `-t`, but use lowercase letters for files | 
|  | that are marked as 'fsmonitor valid' (see | 
|  | linkgit:git-update-index[1]). | 
|  |  | 
|  | --full-name:: | 
|  | When run from a subdirectory, the command usually | 
|  | outputs paths relative to the current directory.  This | 
|  | option forces paths to be output relative to the project | 
|  | top directory. | 
|  |  | 
|  | --recurse-submodules:: | 
|  | Recursively calls ls-files on each active submodule in the repository. | 
|  | Currently there is only support for the --cached mode. | 
|  |  | 
|  | --abbrev[=<n>]:: | 
|  | Instead of showing the full 40-byte hexadecimal object | 
|  | lines, show only a partial prefix. | 
|  | Non default number of digits can be specified with --abbrev=<n>. | 
|  |  | 
|  | --debug:: | 
|  | After each line that describes a file, add more data about its | 
|  | cache entry.  This is intended to show as much information as | 
|  | possible for manual inspection; the exact format may change at | 
|  | any time. | 
|  |  | 
|  | --eol:: | 
|  | Show <eolinfo> and <eolattr> of files. | 
|  | <eolinfo> is the file content identification used by Git when | 
|  | the "text" attribute is "auto" (or not set and core.autocrlf is not false). | 
|  | <eolinfo> is either "-text", "none", "lf", "crlf", "mixed" or "". | 
|  | + | 
|  | "" means the file is not a regular file, it is not in the index or | 
|  | not accessible in the working tree. | 
|  | + | 
|  | <eolattr> is the attribute that is used when checking out or committing, | 
|  | it is either "", "-text", "text", "text=auto", "text eol=lf", "text eol=crlf". | 
|  | Since Git 2.10 "text=auto eol=lf" and "text=auto eol=crlf" are supported. | 
|  | + | 
|  | Both the <eolinfo> in the index ("i/<eolinfo>") | 
|  | and in the working tree ("w/<eolinfo>") are shown for regular files, | 
|  | followed by the  ("attr/<eolattr>"). | 
|  |  | 
|  | \--:: | 
|  | Do not interpret any more arguments as options. | 
|  |  | 
|  | <file>:: | 
|  | Files to show. If no files are given all files which match the other | 
|  | specified criteria are shown. | 
|  |  | 
|  | OUTPUT | 
|  | ------ | 
|  | 'git ls-files' just outputs the filenames unless `--stage` is specified in | 
|  | which case it outputs: | 
|  |  | 
|  | [<tag> ]<mode> <object> <stage> <file> | 
|  |  | 
|  | 'git ls-files --eol' will show | 
|  | i/<eolinfo><SPACES>w/<eolinfo><SPACES>attr/<eolattr><SPACE*><TAB><file> | 
|  |  | 
|  | 'git ls-files --unmerged' and 'git ls-files --stage' can be used to examine | 
|  | detailed information on unmerged paths. | 
|  |  | 
|  | For an unmerged path, instead of recording a single mode/SHA-1 pair, | 
|  | the index records up to three such pairs; one from tree O in stage | 
|  | 1, A in stage 2, and B in stage 3.  This information can be used by | 
|  | the user (or the porcelain) to see what should eventually be recorded at the | 
|  | path. (see linkgit:git-read-tree[1] for more information on state) | 
|  |  | 
|  | Without the `-z` option, pathnames with "unusual" characters are | 
|  | quoted as explained for the configuration variable `core.quotePath` | 
|  | (see linkgit:git-config[1]).  Using `-z` the filename is output | 
|  | verbatim and the line is terminated by a NUL byte. | 
|  |  | 
|  |  | 
|  | EXCLUDE PATTERNS | 
|  | ---------------- | 
|  |  | 
|  | 'git ls-files' can use a list of "exclude patterns" when | 
|  | traversing the directory tree and finding files to show when the | 
|  | flags --others or --ignored are specified.  linkgit:gitignore[5] | 
|  | specifies the format of exclude patterns. | 
|  |  | 
|  | These exclude patterns come from these places, in order: | 
|  |  | 
|  | 1. The command-line flag --exclude=<pattern> specifies a | 
|  | single pattern.  Patterns are ordered in the same order | 
|  | they appear in the command line. | 
|  |  | 
|  | 2. The command-line flag --exclude-from=<file> specifies a | 
|  | file containing a list of patterns.  Patterns are ordered | 
|  | in the same order they appear in the file. | 
|  |  | 
|  | 3. The command-line flag --exclude-per-directory=<name> specifies | 
|  | a name of the file in each directory 'git ls-files' | 
|  | examines, normally `.gitignore`.  Files in deeper | 
|  | directories take precedence.  Patterns are ordered in the | 
|  | same order they appear in the files. | 
|  |  | 
|  | A pattern specified on the command line with --exclude or read | 
|  | from the file specified with --exclude-from is relative to the | 
|  | top of the directory tree.  A pattern read from a file specified | 
|  | by --exclude-per-directory is relative to the directory that the | 
|  | pattern file appears in. | 
|  |  | 
|  | SEE ALSO | 
|  | -------- | 
|  | linkgit:git-read-tree[1], linkgit:gitignore[5] | 
|  |  | 
|  | GIT | 
|  | --- | 
|  | Part of the linkgit:git[1] suite |