hg-grep - Man Page

search for a pattern in specified files

Synopsis

hg grep [--diff] [OPTION]... PATTERN [FILE]...

Description

Search the working directory or revision history for a regular expression in the specified files for the entire repository.

By default, grep searches the repository files in the working directory and prints the files where it finds a match. To specify historical revisions instead of the working directory, use the --rev flag.

To search instead historical revision differences that contains a change in match status ("-" for a match that becomes a non-match, or "+" for a non-match that becomes a match), use the --diff flag.

PATTERN can be any Python (roughly Perl-compatible) regular expression.

If no FILEs are specified and the --rev flag isn't supplied, all files in the working directory are searched. When using the --rev flag and specifying FILEs, use the --follow argument to also follow the specified FILEs across renames and copies.

Template:

The following keywords are supported in addition to the common template keywords and functions. See also hg help templates.

change

String. Character denoting insertion + or removal -. Available if --diff is specified.

lineno

Integer. Line number of the match.

path

String. Repository-absolute path of the file.

texts

List of text chunks.

And each entry of {texts} provides the following sub-keywords.

matched

Boolean. True if the chunk matches the specified pattern.

text

String. Chunk content.

See hg help templates.operators for the list expansion syntax.

Returns 0 if a match is found, 1 otherwise.

Options

-0,  --print0

end fields with NUL

--all

an alias to --diff (DEPRECATED)

--diff

search revision differences for when the pattern was added or removed

-a,  --text

treat all files as text

-f,  --follow

follow changeset history, or file history across copies and renames

-i,  --ignore-case

ignore case when matching

-l,  --files-with-matches

print only filenames and revisions that match

-n,  --line-number

print matching line numbers

-r,--rev <REV[+]>

search files changed within revision range

--all-files

include all files in the changeset while grepping (DEPRECATED)

-u,  --user

list the author (long with -v)

-d,  --date

list the date (short with -q)

-T,--template <TEMPLATE>

display with template

-I,--include <PATTERN[+]>

include names matching the given patterns

-X,--exclude <PATTERN[+]>

exclude names matching the given patterns

[+] marked option can be specified multiple times