logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

notmuch-tag - add/remove tags for all messages matching the search terms

Author

       Carl Worth and many others

Description

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

       See notmuch-search-terms 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.

       notmuchtag updates  the  maildir  flags  according  to  tag  changes  if  the  maildir.synchronize_flags
       configuration option is enabled. See notmuch-config 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 notmuchtag invocations. See TAGFILEFORMAT 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.

Name

       notmuch-tag - add/remove tags for all messages matching the search terms

See Also

notmuch,   notmuch-config,   notmuch-count,  notmuch-dump,  notmuch-hooks,  notmuch-insert,  notmuch-new,
       notmuch-reply, notmuch-restore, notmuch-search, notmuch-search-terms, notmuch-show,

Synopsis

notmuchtag [options ...] +<tag>|-<tag> [--] <search-term> ...

       notmuchtag--batch [--input=<filename>]

Tag File Format

       The input must consist of lines of the format:

       +<tag>|-<tag> [...] [--] <query>

       Each  line  is  interpreted similarly to notmuchtag 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> mustnot 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 spaceintags

          +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