| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 1 | git-grep(1) | 
|  | 2 | =========== | 
|  | 3 |  | 
|  | 4 | NAME | 
|  | 5 | ---- | 
| Junio C Hamano | 0107892 | 2006-03-10 00:31:47 | [diff] [blame] | 6 | git-grep - Print lines matching a pattern | 
| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 7 |  | 
|  | 8 |  | 
|  | 9 | SYNOPSIS | 
|  | 10 | -------- | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 11 | [verse] | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 12 | 'git grep' [-a | --text] [-I] [-i | --ignore-case] [-w | --word-regexp] | 
| Junio C Hamano | 97efb00 | 2006-09-16 18:16:04 | [diff] [blame] | 13 | [-v | --invert-match] [-h|-H] [--full-name] | 
| Junio C Hamano | 9882a52 | 2007-04-27 08:22:22 | [diff] [blame] | 14 | [-E | --extended-regexp] [-G | --basic-regexp] | 
| Junio C Hamano | 084228c | 2011-05-30 08:13:52 | [diff] [blame] | 15 | [-P | --perl-regexp] | 
|  | 16 | [-F | --fixed-strings] [-n | --line-number] | 
| Junio C Hamano | 9882a52 | 2007-04-27 08:22:22 | [diff] [blame] | 17 | [-l | --files-with-matches] [-L | --files-without-match] | 
| Junio C Hamano | 7d44952 | 2010-07-01 00:08:51 | [diff] [blame] | 18 | [(-O | --open-files-in-pager) [<pager>]] | 
| Junio C Hamano | a476efa | 2008-10-10 15:31:42 | [diff] [blame] | 19 | [-z | --null] | 
| Junio C Hamano | 83b3547 | 2010-01-29 05:02:13 | [diff] [blame] | 20 | [-c | --count] [--all-match] [-q | --quiet] | 
| Junio C Hamano | 9f88386 | 2009-08-11 06:23:52 | [diff] [blame] | 21 | [--max-depth <depth>] | 
| Junio C Hamano | 4aa0bcc | 2010-03-03 05:13:12 | [diff] [blame] | 22 | [--color[=<when>] | --no-color] | 
| Junio C Hamano | 0ff9816 | 2012-03-31 18:19:09 | [diff] [blame] | 23 | [--break] [--heading] [-p | --show-function] | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 24 | [-A <post-context>] [-B <pre-context>] [-C <context>] | 
| Junio C Hamano | 0ff9816 | 2012-03-31 18:19:09 | [diff] [blame] | 25 | [-W | --function-context] | 
| Junio C Hamano | 9882a52 | 2007-04-27 08:22:22 | [diff] [blame] | 26 | [-f <file>] [-e] <pattern> | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 27 | [--and|--or|--not|(|)|-e <pattern>...] | 
| Junio C Hamano | 5a73f30 | 2011-10-14 05:58:34 | [diff] [blame] | 28 | [ [--exclude-standard] [--cached | --no-index | --untracked] | <tree>...] | 
| Junio C Hamano | 74a198f | 2010-02-22 00:13:31 | [diff] [blame] | 29 | [--] [<pathspec>...] | 
| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 30 |  | 
|  | 31 | DESCRIPTION | 
|  | 32 | ----------- | 
| Junio C Hamano | 74a198f | 2010-02-22 00:13:31 | [diff] [blame] | 33 | Look for specified patterns in the tracked files in the work tree, blobs | 
| Junio C Hamano | 0364a71 | 2012-05-25 20:02:36 | [diff] [blame^] | 34 | registered in the index file, or blobs in given tree objects. Patterns | 
|  | 35 | are lists of one or more search expressions separated by newline | 
|  | 36 | characters. An empty string as search expression matches all lines. | 
| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 37 |  | 
|  | 38 |  | 
| Junio C Hamano | a03ac86 | 2011-04-02 04:32:29 | [diff] [blame] | 39 | CONFIGURATION | 
|  | 40 | ------------- | 
|  | 41 |  | 
|  | 42 | grep.lineNumber:: | 
|  | 43 | If set to true, enable '-n' option by default. | 
|  | 44 |  | 
|  | 45 | grep.extendedRegexp:: | 
|  | 46 | If set to true, enable '--extended-regexp' option by default. | 
|  | 47 |  | 
|  | 48 |  | 
| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 49 | OPTIONS | 
|  | 50 | ------- | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 51 | --cached:: | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 52 | Instead of searching tracked files in the working tree, search | 
|  | 53 | blobs registered in the index file. | 
|  | 54 |  | 
|  | 55 | --no-index:: | 
| Junio C Hamano | 5a73f30 | 2011-10-14 05:58:34 | [diff] [blame] | 56 | Search files in the current directory that is not managed by git. | 
|  | 57 |  | 
|  | 58 | --untracked:: | 
|  | 59 | In addition to searching in the tracked files in the working | 
|  | 60 | tree, search also in untracked files. | 
|  | 61 |  | 
|  | 62 | --no-exclude-standard:: | 
|  | 63 | Also search in ignored files by not honoring the `.gitignore` | 
|  | 64 | mechanism. Only useful with `--untracked`. | 
|  | 65 |  | 
|  | 66 | --exclude-standard:: | 
|  | 67 | Do not pay attention to ignored files specified via the	`.gitignore` | 
|  | 68 | mechanism. Only useful when searching files in the current directory | 
|  | 69 | with `--no-index`. | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 70 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 71 | -a:: | 
|  | 72 | --text:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 73 | Process binary files as if they were text. | 
|  | 74 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 75 | -i:: | 
|  | 76 | --ignore-case:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 77 | Ignore case differences between the patterns and the | 
|  | 78 | files. | 
|  | 79 |  | 
| Junio C Hamano | 9882a52 | 2007-04-27 08:22:22 | [diff] [blame] | 80 | -I:: | 
|  | 81 | Don't match the pattern in binary files. | 
|  | 82 |  | 
| Junio C Hamano | 9f88386 | 2009-08-11 06:23:52 | [diff] [blame] | 83 | --max-depth <depth>:: | 
| Junio C Hamano | 74a198f | 2010-02-22 00:13:31 | [diff] [blame] | 84 | For each <pathspec> given on command line, descend at most <depth> | 
| Junio C Hamano | 9f88386 | 2009-08-11 06:23:52 | [diff] [blame] | 85 | levels of directories. A negative value means no limit. | 
| Junio C Hamano | bfeab4e | 2012-01-19 00:51:27 | [diff] [blame] | 86 | This option is ignored if <pathspec> contains active wildcards. | 
|  | 87 | In other words if "a*" matches a directory named "a*", | 
|  | 88 | "*" is matched literally so --max-depth is still effective. | 
| Junio C Hamano | 9f88386 | 2009-08-11 06:23:52 | [diff] [blame] | 89 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 90 | -w:: | 
|  | 91 | --word-regexp:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 92 | Match the pattern only at word boundary (either begin at the | 
|  | 93 | beginning of a line, or preceded by a non-word character; end at | 
|  | 94 | the end of a line or followed by a non-word character). | 
|  | 95 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 96 | -v:: | 
|  | 97 | --invert-match:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 98 | Select non-matching lines. | 
|  | 99 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 100 | -h:: | 
|  | 101 | -H:: | 
| Junio C Hamano | 97efb00 | 2006-09-16 18:16:04 | [diff] [blame] | 102 | By default, the command shows the filename for each | 
|  | 103 | match. `-h` option is used to suppress this output. | 
|  | 104 | `-H` is there for completeness and does not do anything | 
|  | 105 | except it overrides `-h` given earlier on the command | 
|  | 106 | line. | 
|  | 107 |  | 
| Junio C Hamano | 85e45fa | 2006-08-13 07:47:41 | [diff] [blame] | 108 | --full-name:: | 
|  | 109 | When run from a subdirectory, the command usually | 
|  | 110 | outputs paths relative to the current directory. This | 
|  | 111 | option forces paths to be output relative to the project | 
|  | 112 | top directory. | 
|  | 113 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 114 | -E:: | 
|  | 115 | --extended-regexp:: | 
|  | 116 | -G:: | 
|  | 117 | --basic-regexp:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 118 | Use POSIX extended/basic regexp for patterns. Default | 
|  | 119 | is to use basic regexp. | 
|  | 120 |  | 
| Junio C Hamano | 084228c | 2011-05-30 08:13:52 | [diff] [blame] | 121 | -P:: | 
|  | 122 | --perl-regexp:: | 
|  | 123 | Use Perl-compatible regexp for patterns. Requires libpcre to be | 
|  | 124 | compiled in. | 
|  | 125 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 126 | -F:: | 
|  | 127 | --fixed-strings:: | 
| Junio C Hamano | 9882a52 | 2007-04-27 08:22:22 | [diff] [blame] | 128 | Use fixed strings for patterns (don't interpret pattern | 
|  | 129 | as a regex). | 
|  | 130 |  | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 131 | -n:: | 
| Junio C Hamano | 2906d34 | 2011-03-29 02:19:17 | [diff] [blame] | 132 | --line-number:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 133 | Prefix the line number to matching lines. | 
|  | 134 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 135 | -l:: | 
|  | 136 | --files-with-matches:: | 
|  | 137 | --name-only:: | 
|  | 138 | -L:: | 
|  | 139 | --files-without-match:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 140 | Instead of showing every matched line, show only the | 
|  | 141 | names of files that contain (or do not contain) matches. | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 142 | For better compatibility with 'git diff', `--name-only` is a | 
|  | 143 | synonym for `--files-with-matches`. | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 144 |  | 
| Junio C Hamano | 7d44952 | 2010-07-01 00:08:51 | [diff] [blame] | 145 | -O [<pager>]:: | 
|  | 146 | --open-files-in-pager [<pager>]:: | 
|  | 147 | Open the matching files in the pager (not the output of 'grep'). | 
|  | 148 | If the pager happens to be "less" or "vi", and the user | 
|  | 149 | specified only one pattern, the first file is positioned at | 
|  | 150 | the first match automatically. | 
|  | 151 |  | 
| Junio C Hamano | a476efa | 2008-10-10 15:31:42 | [diff] [blame] | 152 | -z:: | 
|  | 153 | --null:: | 
|  | 154 | Output \0 instead of the character that normally follows a | 
|  | 155 | file name. | 
|  | 156 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 157 | -c:: | 
|  | 158 | --count:: | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 159 | Instead of showing every matched line, show the number of | 
|  | 160 | lines that match. | 
|  | 161 |  | 
| Junio C Hamano | 4aa0bcc | 2010-03-03 05:13:12 | [diff] [blame] | 162 | --color[=<when>]:: | 
| Junio C Hamano | d257cff | 2009-03-18 05:27:16 | [diff] [blame] | 163 | Show colored matches. | 
| Junio C Hamano | 4aa0bcc | 2010-03-03 05:13:12 | [diff] [blame] | 164 | The value must be always (the default), never, or auto. | 
| Junio C Hamano | d257cff | 2009-03-18 05:27:16 | [diff] [blame] | 165 |  | 
|  | 166 | --no-color:: | 
|  | 167 | Turn off match highlighting, even when the configuration file | 
|  | 168 | gives the default to color output. | 
| Junio C Hamano | 4aa0bcc | 2010-03-03 05:13:12 | [diff] [blame] | 169 | Same as `--color=never`. | 
| Junio C Hamano | d257cff | 2009-03-18 05:27:16 | [diff] [blame] | 170 |  | 
| Junio C Hamano | 4c4b012 | 2011-06-30 01:19:32 | [diff] [blame] | 171 | --break:: | 
|  | 172 | Print an empty line between matches from different files. | 
|  | 173 |  | 
|  | 174 | --heading:: | 
|  | 175 | Show the filename above the matches in that file instead of | 
|  | 176 | at the start of each shown line. | 
|  | 177 |  | 
| Junio C Hamano | 48bc1ce | 2009-07-09 16:49:19 | [diff] [blame] | 178 | -p:: | 
|  | 179 | --show-function:: | 
|  | 180 | Show the preceding line that contains the function name of | 
|  | 181 | the match, unless the matching line is a function name itself. | 
|  | 182 | The name is determined in the same way as 'git diff' works out | 
|  | 183 | patch hunk headers (see 'Defining a custom hunk-header' in | 
|  | 184 | linkgit:gitattributes[5]). | 
|  | 185 |  | 
| Junio C Hamano | 9775d40 | 2011-08-11 22:27:20 | [diff] [blame] | 186 | -<num>:: | 
|  | 187 | -C <num>:: | 
|  | 188 | --context <num>:: | 
|  | 189 | Show <num> leading and trailing lines, and place a line | 
|  | 190 | containing `--` between contiguous groups of matches. | 
|  | 191 |  | 
|  | 192 | -A <num>:: | 
|  | 193 | --after-context <num>:: | 
|  | 194 | Show <num> trailing lines, and place a line containing | 
|  | 195 | `--` between contiguous groups of matches. | 
|  | 196 |  | 
|  | 197 | -B <num>:: | 
|  | 198 | --before-context <num>:: | 
|  | 199 | Show <num> leading lines, and place a line containing | 
|  | 200 | `--` between contiguous groups of matches. | 
|  | 201 |  | 
|  | 202 | -W:: | 
|  | 203 | --function-context:: | 
|  | 204 | Show the surrounding text from the previous line containing a | 
|  | 205 | function name up to the one before the next function name, | 
|  | 206 | effectively showing the whole function in which the match was | 
|  | 207 | found. | 
|  | 208 |  | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 209 | -f <file>:: | 
|  | 210 | Read patterns from <file>, one per line. | 
|  | 211 |  | 
| Junio C Hamano | 3901ffb | 2006-06-26 23:46:53 | [diff] [blame] | 212 | -e:: | 
|  | 213 | The next parameter is the pattern. This option has to be | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 214 | used for patterns starting with `-` and should be used in | 
| Junio C Hamano | 0044202 | 2006-08-03 00:29:36 | [diff] [blame] | 215 | scripts passing user input to grep. Multiple patterns are | 
|  | 216 | combined by 'or'. | 
|  | 217 |  | 
| Junio C Hamano | eb41599 | 2008-06-08 22:49:47 | [diff] [blame] | 218 | --and:: | 
|  | 219 | --or:: | 
|  | 220 | --not:: | 
|  | 221 | ( ... ):: | 
| Junio C Hamano | f9771f6 | 2007-01-17 17:42:30 | [diff] [blame] | 222 | Specify how multiple patterns are combined using Boolean | 
| Junio C Hamano | 0044202 | 2006-08-03 00:29:36 | [diff] [blame] | 223 | expressions. `--or` is the default operator. `--and` has | 
|  | 224 | higher precedence than `--or`. `-e` has to be used for all | 
|  | 225 | patterns. | 
| Junio C Hamano | 3901ffb | 2006-06-26 23:46:53 | [diff] [blame] | 226 |  | 
| Junio C Hamano | fbe0052 | 2006-10-19 05:58:48 | [diff] [blame] | 227 | --all-match:: | 
|  | 228 | When giving multiple pattern expressions combined with `--or`, | 
|  | 229 | this flag is specified to limit the match to files that | 
|  | 230 | have lines to match all of them. | 
|  | 231 |  | 
| Junio C Hamano | 83b3547 | 2010-01-29 05:02:13 | [diff] [blame] | 232 | -q:: | 
|  | 233 | --quiet:: | 
|  | 234 | Do not output matched lines; instead, exit with status 0 when | 
|  | 235 | there is a match and with non-zero status when there isn't. | 
|  | 236 |  | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 237 | <tree>...:: | 
|  | 238 | Instead of searching tracked files in the working tree, search | 
|  | 239 | blobs in the given trees. | 
| Junio C Hamano | 617fdb8 | 2006-05-16 02:14:21 | [diff] [blame] | 240 |  | 
| Junio C Hamano | 0044202 | 2006-08-03 00:29:36 | [diff] [blame] | 241 | \--:: | 
| Junio C Hamano | a6331a8 | 2006-01-22 07:50:33 | [diff] [blame] | 242 | Signals the end of options; the rest of the parameters | 
| Junio C Hamano | 74a198f | 2010-02-22 00:13:31 | [diff] [blame] | 243 | are <pathspec> limiters. | 
| Junio C Hamano | a6331a8 | 2006-01-22 07:50:33 | [diff] [blame] | 244 |  | 
| Junio C Hamano | 74a198f | 2010-02-22 00:13:31 | [diff] [blame] | 245 | <pathspec>...:: | 
|  | 246 | If given, limit the search to paths matching at least one pattern. | 
|  | 247 | Both leading paths match and glob(7) patterns are supported. | 
| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 248 |  | 
| Junio C Hamano | 636c8b2 | 2010-03-07 22:25:17 | [diff] [blame] | 249 | Examples | 
|  | 250 | -------- | 
| Junio C Hamano | 0044202 | 2006-08-03 00:29:36 | [diff] [blame] | 251 |  | 
| Junio C Hamano | b76a686 | 2012-05-02 22:02:46 | [diff] [blame] | 252 | `git grep 'time_t' -- '*.[ch]'`:: | 
| Junio C Hamano | 74a198f | 2010-02-22 00:13:31 | [diff] [blame] | 253 | Looks for `time_t` in all tracked .c and .h files in the working | 
|  | 254 | directory and its subdirectories. | 
|  | 255 |  | 
| Junio C Hamano | b76a686 | 2012-05-02 22:02:46 | [diff] [blame] | 256 | `git grep -e '#define' --and \( -e MAX_PATH -e PATH_MAX \)`:: | 
| Junio C Hamano | 0044202 | 2006-08-03 00:29:36 | [diff] [blame] | 257 | Looks for a line that has `#define` and either `MAX_PATH` or | 
|  | 258 | `PATH_MAX`. | 
|  | 259 |  | 
| Junio C Hamano | 16ebcd0 | 2011-08-05 00:05:45 | [diff] [blame] | 260 | `git grep --all-match -e NODE -e Unexpected`:: | 
| Junio C Hamano | fbe0052 | 2006-10-19 05:58:48 | [diff] [blame] | 261 | Looks for a line that has `NODE` or `Unexpected` in | 
|  | 262 | files that have lines that match both. | 
|  | 263 |  | 
| Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 264 | GIT | 
|  | 265 | --- | 
| Junio C Hamano | f7c042d | 2008-06-06 22:50:53 | [diff] [blame] | 266 | Part of the linkgit:git[1] suite |