Show More
filesets.txt
79 lines
| 2.1 KiB
| text/plain
|
TextLexer
Matt Mackall
|
r14686 | Mercurial supports a functional language for selecting a set of | ||
Mads Kiilerich
|
r18960 | files. | ||
Matt Mackall
|
r14686 | |||
Like other file patterns, this pattern type is indicated by a prefix, | ||||
'set:'. The language supports a number of predicates which are joined | ||||
by infix operators. Parenthesis can be used for grouping. | ||||
Identifiers such as filenames or patterns must be quoted with single | ||||
or double quotes if they contain characters outside of | ||||
``[.*{}[]?/\_a-zA-Z0-9\x80-\xff]`` or if they match one of the | ||||
predefined predicates. This generally applies to file patterns other | ||||
Yuya Nishihara
|
r35759 | than globs and arguments for predicates. Pattern prefixes such as | ||
``path:`` may be specified without quoting. | ||||
Matt Mackall
|
r14686 | |||
Special characters can be used in quoted identifiers by escaping them, | ||||
e.g., ``\n`` is interpreted as a newline. To prevent them from being | ||||
interpreted, strings can be prefixed with ``r``, e.g. ``r'...'``. | ||||
Matt Harbison
|
r30729 | See also :hg:`help patterns`. | ||
Matt Harbison
|
r30731 | Operators | ||
========= | ||||
Matt Harbison
|
r30729 | |||
Matt Mackall
|
r14686 | There is a single prefix operator: | ||
``not x`` | ||||
Files not in x. Short form is ``! x``. | ||||
These are the supported infix operators: | ||||
``x and y`` | ||||
The intersection of files in x and y. Short form is ``x & y``. | ||||
``x or y`` | ||||
The union of files in x and y. There are two alternative short | ||||
forms: ``x | y`` and ``x + y``. | ||||
``x - y`` | ||||
Files in x but not in y. | ||||
Matt Harbison
|
r30729 | Predicates | ||
========== | ||||
Matt Mackall
|
r14686 | The following predicates are supported: | ||
.. predicatesmarker | ||||
Matt Harbison
|
r30729 | Examples | ||
======== | ||||
Matt Mackall
|
r14686 | Some sample queries: | ||
- Show status of files that appear to be binary in the working directory:: | ||||
hg status -A "set:binary()" | ||||
- Forget files that are in .hgignore but are already tracked:: | ||||
hg forget "set:hgignore() and not ignored()" | ||||
- Find text files that contain a string:: | ||||
FUJIWARA Katsunori
|
r23109 | hg files "set:grep(magic) and not binary()" | ||
Matt Mackall
|
r14686 | |||
- Find C files in a non-standard encoding:: | ||||
FUJIWARA Katsunori
|
r23109 | hg files "set:**.c and not encoding('UTF-8')" | ||
Matt Mackall
|
r14686 | |||
- Revert copies of large binary files:: | ||||
hg revert "set:copied() and binary() and size('>1M')" | ||||
Pierre-Yves David
|
r31193 | - Revert files that were added to the working directory:: | ||
Yuya Nishihara
|
r31286 | hg revert "set:revs('wdir()', added())" | ||
Pierre-Yves David
|
r31193 | |||
Arne Babenhauserheide
|
r14829 | - Remove files listed in foo.lst that contain the letter a or b:: | ||
Matt Mackall
|
r14686 | |||
Yuya Nishihara
|
r35759 | hg remove "set: listfile:foo.lst and (**a* or **b*)" | ||