unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob 548c7aa4dabf1f26df170a77af76b94f00079c54 3702 bytes (raw)
name: doc/man1/notmuch-tag.rst 	 # note: path name is non-authoritative(*)

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
 
===========
notmuch-tag
===========

SYNOPSIS
========

**notmuch** **tag** [options ...] **+<tag>** **-<tag>** [--] **<search-term>** **.[..]** **notmuch** **tag** **--batch** [--input=]

DESCRIPTION
===========

Add/remove tags for all messages matching the search terms.

See *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
*notmuch-config(1)* for details.

Supported options for *tag* include

    ``--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.

    ``--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.

    ``--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
========

*notmuch(1)*, *notmuch-config(1)*, *notmuch-count(1)*,
*notmuch-dump(1)*, *notmuch-hooks(5)*, *notmuch-insert(1)*,
*notmuch-new(1)*, *notmuch-reply(1)*, *notmuch-restore(1)*,
*notmuch-search(1)*, *notmuch-search-terms(7)*, *notmuch-show(1)*,

debug log:

solving 548c7aa ...
found 548c7aa in https://yhetil.org/notmuch/1393114575-8756-2-git-send-email-david@tethera.net/

applying [1/1] https://yhetil.org/notmuch/1393114575-8756-2-git-send-email-david@tethera.net/
diff --git a/doc/man1/notmuch-tag.rst b/doc/man1/notmuch-tag.rst
new file mode 100644
index 0000000..548c7aa

Checking patch doc/man1/notmuch-tag.rst...
Applied patch doc/man1/notmuch-tag.rst cleanly.

index at:
100644 548c7aa4dabf1f26df170a77af76b94f00079c54	doc/man1/notmuch-tag.rst

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://yhetil.org/notmuch.git/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).