Also, if any matches were found, grep will exit with a status of 0, but if no matches were found it will exit with a status of 1. This is useful for building shell scripts that use grep as a condition for, for example, the if statement.
When invoked as
egrep
the syntax of the
expr
is slightly different; See below.
(grep) (egrep) (explanation)
c c a single (non-meta) character matches itself.
. . matches any single character except newline.
\? ? postfix operator; preceeding item is optional.
* * postfix operator; preceeding item 0 or
more times.
\+ + postfix operator; preceeding item 1 or
more times.
\| | infix operator; matches either
argument.
^ ^ matches the empty string at the beginning of a line.
$ $ matches the empty string at the end of a line.
\< \< matches the empty string at the beginning of a word.
\> \> matches the empty string at the end of a word.
[chars] [chars] match any character in the given class; if the
first character after [ is ^, match any character
not in the given class; a range of characters may
be specified by first-last; for example, \W
(below) is equivalent to the class [^A-Za-z0-9]
\( \) ( ) parentheses are used to override operator precedence.
\digit \digit \n matches a repeat of the text
matched earlier in the regexp by the subexpression inside the nth
opening parenthesis.
\ \ any special character may be preceded
by a backslash to match it literally.
(the following are for compatibility with GNU Emacs)
\b \b matches the empty string at the edge of a word.
\B \B matches the empty string if not at the edge of a word.
\w \w matches word-constituent characters (letters & digits).
\W \W matches characters that are not word-constituent.
Operator precedence is (highest to lowest) ?, *, and +, concatenation, and finally |. All other constructs are syntactically identical to normal characters. For the truly interested, the file dfa.c describes (and implements) the exact grammar understood by the parser.
-b prints a byte offset instead of a block offset.
The {m,n} construct of System V grep is not implemented.
There is also a newsgroup, gnu.utils.bug, for reporting FSF utility programs' bugs and fixes; but before reporting something as a bug, please try to be sure that it really is a bug, not a misunderstanding or a deliberate feature. Also, include the version number of the utility program you are running in every bug report that you send in. Please do not send anything but bug reports to this newsgroup.
GNU grep is free; anyone may redistribute copies of grep to anyone under the terms stated in the GNU General Public License, a copy of which may be found in each copy of GNU Emacs. See also the comment at the beginning of the source code file grep.c.
Copies of GNU grep may sometimes be received packaged with distributions of Unix systems, but it is never included in the scope of any license covering those systems. Such inclusion violates the terms on which distribution is permitted. In fact, the primary purpose of the General Public License is to prohibit anyone from attaching any other restrictions to redistribution of any of the Free Software Foundation programs.
James A. Woods is responsible for the hybridized search strategy of using Boyer-Moore-Gosper fixed-string search as a filter before calling the general regexp matcher.
Arthur David Olson contributed code that finds fixed strings for the aforementioned BMG search for a large class of regexps.
Richard Stallman wrote the backtracking regexp matcher that is used for \digit backreferences, as well as the getopt that is provided for 4.2BSD sites. The backtracking matcher was originally written for GNU Emacs.
D. A. Gwyn wrote the C alloca emulation that is provided so System V machines can run this program. (Alloca is used only by RMS' backtracking matcher, and then only rarely, so there is no loss if your machine doesn't have a "real" alloca.)
Scott Anderson and Henry Spencer designed the regression tests used in the "regress" script.
Paul Placeway wrote the original version of this manual page.