Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 1 | gitignore(5) |
| 2 | ============ |
| 3 | |
| 4 | NAME |
| 5 | ---- |
| 6 | gitignore - Specifies intentionally untracked files to ignore |
| 7 | |
| 8 | SYNOPSIS |
| 9 | -------- |
Junio C Hamano | ea1ac8d | 2018-07-18 20:16:48 | [diff] [blame] | 10 | $XDG_CONFIG_HOME/git/ignore, $GIT_DIR/info/exclude, .gitignore |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 11 | |
| 12 | DESCRIPTION |
| 13 | ----------- |
| 14 | |
| 15 | A `gitignore` file specifies intentionally untracked files that |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 16 | Git should ignore. |
| 17 | Files already tracked by Git are not affected; see the NOTES |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 18 | below for details. |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 19 | |
Junio C Hamano | 915cd9b | 2008-07-20 01:24:17 | [diff] [blame] | 20 | Each line in a `gitignore` file specifies a pattern. |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 21 | When deciding whether to ignore a path, Git normally checks |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 22 | `gitignore` patterns from multiple sources, with the following |
Junio C Hamano | de9879a | 2007-07-22 09:33:42 | [diff] [blame] | 23 | order of precedence, from highest to lowest (within one level of |
| 24 | precedence, the last matching pattern decides the outcome): |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 25 | |
Junio C Hamano | de9879a | 2007-07-22 09:33:42 | [diff] [blame] | 26 | * Patterns read from the command line for those commands that support |
| 27 | them. |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 28 | |
| 29 | * Patterns read from a `.gitignore` file in the same directory |
Junio C Hamano | 20cf493 | 2021-07-28 21:02:52 | [diff] [blame] | 30 | as the path, or in any parent directory (up to the top-level of the working |
| 31 | tree), with patterns in the higher level files being overridden by those in |
| 32 | lower level files down to the directory containing the file. These patterns |
| 33 | match relative to the location of the `.gitignore` file. A project normally |
| 34 | includes such `.gitignore` files in its repository, containing patterns for |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 35 | files generated as part of the project build. |
| 36 | |
Junio C Hamano | de9879a | 2007-07-22 09:33:42 | [diff] [blame] | 37 | * Patterns read from `$GIT_DIR/info/exclude`. |
| 38 | |
| 39 | * Patterns read from the file specified by the configuration |
Junio C Hamano | 042f214 | 2016-06-27 18:05:05 | [diff] [blame] | 40 | variable `core.excludesFile`. |
Junio C Hamano | de9879a | 2007-07-22 09:33:42 | [diff] [blame] | 41 | |
Junio C Hamano | 99dc24a | 2008-03-27 23:49:50 | [diff] [blame] | 42 | Which file to place a pattern in depends on how the pattern is meant to |
Junio C Hamano | 4f07aec | 2012-09-25 19:08:44 | [diff] [blame] | 43 | be used. |
| 44 | |
| 45 | * Patterns which should be version-controlled and distributed to |
| 46 | other repositories via clone (i.e., files that all developers will want |
| 47 | to ignore) should go into a `.gitignore` file. |
| 48 | |
| 49 | * Patterns which are |
| 50 | specific to a particular repository but which do not need to be shared |
| 51 | with other related repositories (e.g., auxiliary files that live inside |
| 52 | the repository but are specific to one user's workflow) should go into |
| 53 | the `$GIT_DIR/info/exclude` file. |
| 54 | |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 55 | * Patterns which a user wants Git to |
Junio C Hamano | 4f07aec | 2012-09-25 19:08:44 | [diff] [blame] | 56 | ignore in all situations (e.g., backup or temporary files generated by |
| 57 | the user's editor of choice) generally go into a file specified by |
Junio C Hamano | 322c624 | 2015-03-23 21:32:46 | [diff] [blame] | 58 | `core.excludesFile` in the user's `~/.gitconfig`. Its default value is |
Junio C Hamano | 4f07aec | 2012-09-25 19:08:44 | [diff] [blame] | 59 | $XDG_CONFIG_HOME/git/ignore. If $XDG_CONFIG_HOME is either not set or |
| 60 | empty, $HOME/.config/git/ignore is used instead. |
Junio C Hamano | 99dc24a | 2008-03-27 23:49:50 | [diff] [blame] | 61 | |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 62 | The underlying Git plumbing tools, such as |
Junio C Hamano | 1aa40d2 | 2010-01-21 17:46:43 | [diff] [blame] | 63 | 'git ls-files' and 'git read-tree', read |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 64 | `gitignore` patterns specified by command-line options, or from |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 65 | files specified by command-line options. Higher-level Git |
Junio C Hamano | 1aa40d2 | 2010-01-21 17:46:43 | [diff] [blame] | 66 | tools, such as 'git status' and 'git add', |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 67 | use patterns from the sources specified above. |
| 68 | |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 69 | PATTERN FORMAT |
| 70 | -------------- |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 71 | |
| 72 | - A blank line matches no files, so it can serve as a separator |
| 73 | for readability. |
| 74 | |
| 75 | - A line starting with # serves as a comment. |
Junio C Hamano | 6631a09 | 2012-10-10 22:50:57 | [diff] [blame] | 76 | Put a backslash ("`\`") in front of the first hash for patterns |
| 77 | that begin with a hash. |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 78 | |
Junio C Hamano | d701ba3 | 2014-11-06 23:18:05 | [diff] [blame] | 79 | - Trailing spaces are ignored unless they are quoted with backslash |
Junio C Hamano | 81703b2 | 2014-03-14 22:00:27 | [diff] [blame] | 80 | ("`\`"). |
| 81 | |
Junio C Hamano | 6631a09 | 2012-10-10 22:50:57 | [diff] [blame] | 82 | - An optional prefix "`!`" which negates the pattern; any |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 83 | matching file excluded by a previous pattern will become |
Junio C Hamano | 7abb875 | 2016-03-18 22:52:54 | [diff] [blame] | 84 | included again. It is not possible to re-include a file if a parent |
| 85 | directory of that file is excluded. Git doesn't list excluded |
| 86 | directories for performance reasons, so any patterns on contained |
| 87 | files have no effect, no matter where they are defined. |
Junio C Hamano | 6631a09 | 2012-10-10 22:50:57 | [diff] [blame] | 88 | Put a backslash ("`\`") in front of the first "`!`" for patterns |
| 89 | that begin with a literal "`!`", for example, "`\!important!.txt`". |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 90 | |
Junio C Hamano | d0a9940 | 2019-06-21 18:58:41 | [diff] [blame] | 91 | - The slash '/' is used as the directory separator. Separators may |
| 92 | occur at the beginning, middle or end of the `.gitignore` search pattern. |
Junio C Hamano | 26e590a | 2008-02-17 03:53:51 | [diff] [blame] | 93 | |
Junio C Hamano | d0a9940 | 2019-06-21 18:58:41 | [diff] [blame] | 94 | - If there is a separator at the beginning or middle (or both) of the |
| 95 | pattern, then the pattern is relative to the directory level of the |
| 96 | particular `.gitignore` file itself. Otherwise the pattern may also |
| 97 | match at any level below the `.gitignore` level. |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 98 | |
Junio C Hamano | d0a9940 | 2019-06-21 18:58:41 | [diff] [blame] | 99 | - If there is a separator at the end of the pattern then the pattern |
| 100 | will only match directories, otherwise the pattern can match both |
| 101 | files and directories. |
Junio C Hamano | a574a09 | 2010-06-13 19:57:10 | [diff] [blame] | 102 | |
Junio C Hamano | d0a9940 | 2019-06-21 18:58:41 | [diff] [blame] | 103 | - For example, a pattern `doc/frotz/` matches `doc/frotz` directory, |
| 104 | but not `a/doc/frotz` directory; however `frotz/` matches `frotz` |
| 105 | and `a/frotz` that is a directory (all paths are relative from |
| 106 | the `.gitignore` file). |
| 107 | |
| 108 | - An asterisk "`*`" matches anything except a slash. |
| 109 | The character "`?`" matches any one character except "`/`". |
| 110 | The range notation, e.g. `[a-zA-Z]`, can be used to match |
| 111 | one of the characters in a range. See fnmatch(3) and the |
| 112 | FNM_PATHNAME flag for a more detailed description. |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 113 | |
Junio C Hamano | c087f14 | 2013-01-10 23:38:50 | [diff] [blame] | 114 | Two consecutive asterisks ("`**`") in patterns matched against |
| 115 | full pathname may have special meaning: |
| 116 | |
| 117 | - A leading "`**`" followed by a slash means match in all |
| 118 | directories. For example, "`**/foo`" matches file or directory |
Junio C Hamano | 83e0e0b | 2013-11-08 00:30:52 | [diff] [blame] | 119 | "`foo`" anywhere, the same as pattern "`foo`". "`**/foo/bar`" |
Junio C Hamano | c087f14 | 2013-01-10 23:38:50 | [diff] [blame] | 120 | matches file or directory "`bar`" anywhere that is directly |
| 121 | under directory "`foo`". |
| 122 | |
Junio C Hamano | 83e0e0b | 2013-11-08 00:30:52 | [diff] [blame] | 123 | - A trailing "`/**`" matches everything inside. For example, |
| 124 | "`abc/**`" matches all files inside directory "`abc`", relative |
Junio C Hamano | c087f14 | 2013-01-10 23:38:50 | [diff] [blame] | 125 | to the location of the `.gitignore` file, with infinite depth. |
| 126 | |
| 127 | - A slash followed by two consecutive asterisks then a slash |
| 128 | matches zero or more directories. For example, "`a/**/b`" |
| 129 | matches "`a/b`", "`a/x/b`", "`a/x/y/b`" and so on. |
| 130 | |
Junio C Hamano | 06ce83b | 2018-11-13 14:06:12 | [diff] [blame] | 131 | - Other consecutive asterisks are considered regular asterisks and |
| 132 | will match according to the previous rules. |
Junio C Hamano | c087f14 | 2013-01-10 23:38:50 | [diff] [blame] | 133 | |
Junio C Hamano | e0f7146 | 2019-04-09 17:54:45 | [diff] [blame] | 134 | CONFIGURATION |
| 135 | ------------- |
| 136 | |
| 137 | The optional configuration variable `core.excludesFile` indicates a path to a |
| 138 | file containing patterns of file names to exclude, similar to |
| 139 | `$GIT_DIR/info/exclude`. Patterns in the exclude file are used in addition to |
| 140 | those in `$GIT_DIR/info/exclude`. |
| 141 | |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 142 | NOTES |
| 143 | ----- |
| 144 | |
| 145 | The purpose of gitignore files is to ensure that certain files |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 146 | not tracked by Git remain untracked. |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 147 | |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 148 | To stop tracking a file that is currently tracked, use |
Junio C Hamano | 7ab2d20 | 2023-05-10 18:59:24 | [diff] [blame] | 149 | 'git rm --cached' to remove the file from the index. The filename |
| 150 | can then be added to the `.gitignore` file to stop the file from |
| 151 | being reintroduced in later commits. |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 152 | |
Junio C Hamano | 51a55bc | 2021-05-12 05:22:19 | [diff] [blame] | 153 | Git does not follow symbolic links when accessing a `.gitignore` file in |
| 154 | the working tree. This keeps behavior consistent when the file is |
| 155 | accessed from the index or a tree versus from the filesystem. |
| 156 | |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 157 | EXAMPLES |
| 158 | -------- |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 159 | |
Junio C Hamano | 19dcd3f | 2021-10-29 23:20:47 | [diff] [blame] | 160 | - The pattern `hello.*` matches any file or directory |
Junio C Hamano | 458281a | 2021-03-22 21:20:26 | [diff] [blame] | 161 | whose name begins with `hello.`. If one wants to restrict |
Junio C Hamano | d0a9940 | 2019-06-21 18:58:41 | [diff] [blame] | 162 | this only to the directory and not in its subdirectories, |
| 163 | one can prepend the pattern with a slash, i.e. `/hello.*`; |
| 164 | the pattern now matches `hello.txt`, `hello.c` but not |
| 165 | `a/hello.java`. |
| 166 | |
| 167 | - The pattern `foo/` will match a directory `foo` and |
| 168 | paths underneath it, but will not match a regular file |
| 169 | or a symbolic link `foo` (this is consistent with the |
| 170 | way how pathspec works in general in Git) |
| 171 | |
| 172 | - The pattern `doc/frotz` and `/doc/frotz` have the same effect |
| 173 | in any `.gitignore` file. In other words, a leading slash |
| 174 | is not relevant if there is already a middle slash in |
| 175 | the pattern. |
| 176 | |
| 177 | - The pattern "foo/*", matches "foo/test.json" |
| 178 | (a regular file), "foo/bar" (a directory), but it does not match |
| 179 | "foo/bar/hello.c" (a regular file), as the asterisk in the |
| 180 | pattern does not match "bar/hello.c" which has a slash in it. |
| 181 | |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 182 | -------------------------------------------------------------- |
Junio C Hamano | fce7c7e | 2008-07-02 03:06:38 | [diff] [blame] | 183 | $ git status |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 184 | [...] |
| 185 | # Untracked files: |
| 186 | [...] |
| 187 | # Documentation/foo.html |
| 188 | # Documentation/gitignore.html |
| 189 | # file.o |
| 190 | # lib.a |
| 191 | # src/internal.o |
| 192 | [...] |
| 193 | $ cat .git/info/exclude |
| 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 |
Junio C Hamano | fce7c7e | 2008-07-02 03:06:38 | [diff] [blame] | 201 | $ git status |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 202 | [...] |
| 203 | # Untracked files: |
| 204 | [...] |
| 205 | # Documentation/foo.html |
| 206 | [...] |
| 207 | -------------------------------------------------------------- |
| 208 | |
| 209 | Another example: |
| 210 | |
| 211 | -------------------------------------------------------------- |
| 212 | $ cat .gitignore |
| 213 | vmlinux* |
| 214 | $ ls arch/foo/kernel/vm* |
| 215 | arch/foo/kernel/vmlinux.lds.S |
| 216 | $ echo '!/vmlinux*' >arch/foo/kernel/.gitignore |
| 217 | -------------------------------------------------------------- |
| 218 | |
Junio C Hamano | 076ffcc | 2013-02-06 05:13:21 | [diff] [blame] | 219 | The second .gitignore prevents Git from ignoring |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 220 | `arch/foo/kernel/vmlinux.lds.S`. |
| 221 | |
Junio C Hamano | cf77b04 | 2013-12-17 23:54:21 | [diff] [blame] | 222 | Example to exclude everything except a specific directory `foo/bar` |
| 223 | (note the `/*` - without the slash, the wildcard would also exclude |
| 224 | everything within `foo/bar`): |
| 225 | |
| 226 | -------------------------------------------------------------- |
| 227 | $ cat .gitignore |
| 228 | # exclude everything except directory foo/bar |
| 229 | /* |
| 230 | !/foo |
| 231 | /foo/* |
| 232 | !/foo/bar |
| 233 | -------------------------------------------------------------- |
| 234 | |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 235 | SEE ALSO |
| 236 | -------- |
Junio C Hamano | 36d5229 | 2013-01-25 21:32:36 | [diff] [blame] | 237 | linkgit:git-rm[1], |
Junio C Hamano | 36d5229 | 2013-01-25 21:32:36 | [diff] [blame] | 238 | linkgit:gitrepository-layout[5], |
| 239 | linkgit:git-check-ignore[1] |
Junio C Hamano | 2e6ded8 | 2010-12-05 06:20:48 | [diff] [blame] | 240 | |
Junio C Hamano | 679d22d | 2007-06-02 21:13:44 | [diff] [blame] | 241 | GIT |
| 242 | --- |
Junio C Hamano | f7c042d | 2008-06-06 22:50:53 | [diff] [blame] | 243 | Part of the linkgit:git[1] suite |