mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-11-25 04:18:08 +01:00
f2e2f2aa96
Use the program and option directives to document the subcommand options. This unifies a lot of option documentation throughout. This also makes it possible to reference options with :option:`--foo` (within .. program::) or :option:`subcommand --foo` (globally). This is left for later work. See https://www.sphinx-doc.org/en/master/usage/restructuredtext/domains.html#directive-program Note: There is a lot of indentation change, but intentionally there is no reflow. Using 'git diff -w' or 'git show -w' to ignore white space changes makes this a very easy change to review.
121 lines
3.7 KiB
ReStructuredText
121 lines
3.7 KiB
ReStructuredText
.. _notmuch-tag(1):
|
|
|
|
===========
|
|
notmuch-tag
|
|
===========
|
|
|
|
SYNOPSIS
|
|
========
|
|
|
|
**notmuch** **tag** [options ...] +<*tag*>|-<*tag*> [--] <*search-term*> ...
|
|
|
|
**notmuch** **tag** **--batch** [--input=<*filename*>]
|
|
|
|
DESCRIPTION
|
|
===========
|
|
|
|
Add/remove tags for all messages matching the search terms.
|
|
|
|
See :any:`notmuch-search-terms(7)` for details of the supported syntax for
|
|
<*search-term*\ >.
|
|
|
|
Tags prefixed by '+' are added while those prefixed by '-' are removed.
|
|
For each message, tag changes are applied in the order they appear on
|
|
the command line.
|
|
|
|
The beginning of the search terms is recognized by the first argument
|
|
that begins with neither '+' nor '-'. Support for an initial search term
|
|
beginning with '+' or '-' is provided by allowing the user to specify a
|
|
"--" argument to separate the tags from the search terms.
|
|
|
|
**notmuch tag** updates the maildir flags according to tag changes if
|
|
the **maildir.synchronize\_flags** configuration option is enabled. See
|
|
:any:`notmuch-config(1)` for details.
|
|
|
|
Supported options for **tag** include
|
|
|
|
.. program:: tag
|
|
|
|
.. option:: --remove-all
|
|
|
|
Remove all tags from each message matching the search terms before
|
|
applying the tag changes appearing on the command line. This
|
|
means setting the tags of each message to the tags to be added. If
|
|
there are no tags to be added, the messages will have no tags.
|
|
|
|
.. option:: --batch
|
|
|
|
Read batch tagging operations from a file (stdin by default).
|
|
This is more efficient than repeated **notmuch tag**
|
|
invocations. See `TAG FILE FORMAT <#tag_file_format>`__ below for
|
|
the input format. This option is not compatible with specifying
|
|
tagging on the command line.
|
|
|
|
.. option:: --input=<filename>
|
|
|
|
Read input from given file, instead of from stdin. Implies
|
|
``--batch``.
|
|
|
|
TAG FILE FORMAT
|
|
===============
|
|
|
|
The input must consist of lines of the format:
|
|
|
|
+<*tag*\ >\|-<*tag*\ > [...] [--] <*query*\ >
|
|
|
|
Each line is interpreted similarly to **notmuch tag** command line
|
|
arguments. The delimiter is one or more spaces ' '. Any characters in
|
|
<*tag*\ > **may** be hex-encoded with %NN where NN is the hexadecimal
|
|
value of the character. To hex-encode a character with a multi-byte
|
|
UTF-8 encoding, hex-encode each byte. Any spaces in <tag> **must** be
|
|
hex-encoded as %20. Any characters that are not part of <*tag*\ > **must
|
|
not** be hex-encoded.
|
|
|
|
In the future tag:"tag with spaces" style quoting may be supported for
|
|
<*tag*\ > as well; for this reason all double quote characters in
|
|
<*tag*\ > **should** be hex-encoded.
|
|
|
|
The <*query*\ > should be quoted using Xapian boolean term quoting
|
|
rules: if a term contains whitespace or a close paren or starts with a
|
|
double quote, it must be enclosed in double quotes (not including any
|
|
prefix) and double quotes inside the term must be doubled (see below for
|
|
examples).
|
|
|
|
Leading and trailing space ' ' is ignored. Empty lines and lines
|
|
beginning with '#' are ignored.
|
|
|
|
EXAMPLE
|
|
-------
|
|
|
|
The following shows a valid input to batch tagging. Note that only the
|
|
isolated '\*' acts as a wildcard. Also note the two different quotings
|
|
of the tag **space in tags**
|
|
|
|
::
|
|
|
|
+winner *
|
|
+foo::bar%25 -- (One and Two) or (One and tag:winner)
|
|
+found::it -- tag:foo::bar%
|
|
# ignore this line and the next
|
|
|
|
+space%20in%20tags -- Two
|
|
# add tag '(tags)', among other stunts.
|
|
+crazy{ +(tags) +&are +#possible\ -- tag:"space in tags"
|
|
+match*crazy -- tag:crazy{
|
|
+some_tag -- id:"this is ""nauty)"""
|
|
|
|
SEE ALSO
|
|
========
|
|
|
|
:any:`notmuch(1)`,
|
|
:any:`notmuch-config(1)`,
|
|
:any:`notmuch-count(1)`,
|
|
:any:`notmuch-dump(1)`,
|
|
:any:`notmuch-hooks(5)`,
|
|
:any:`notmuch-insert(1)`,
|
|
:any:`notmuch-new(1)`,
|
|
:any:`notmuch-reply(1)`,
|
|
:any:`notmuch-restore(1)`,
|
|
:any:`notmuch-search(1)`,
|
|
:any:`notmuch-search-terms(7)`,
|
|
:any:`notmuch-show(1)`,
|