2013-08-03 13:29:40 +02:00
|
|
|
.TH NOTMUCH-SHOW 1 2013-08-03 "Notmuch 0.16"
|
2011-12-19 03:38:24 +01:00
|
|
|
.SH NAME
|
2012-06-24 23:53:27 +02:00
|
|
|
notmuch-show \- show messages matching the given search terms
|
2011-12-19 03:38:24 +01:00
|
|
|
.SH SYNOPSIS
|
|
|
|
|
|
|
|
.B notmuch show
|
|
|
|
.RI "[" options "...] <" search-term ">..."
|
|
|
|
|
|
|
|
.SH DESCRIPTION
|
|
|
|
|
|
|
|
Shows all messages matching the search terms.
|
|
|
|
|
2011-12-20 02:41:48 +01:00
|
|
|
See \fBnotmuch-search-terms\fR(7)
|
|
|
|
for details of the supported syntax for <search-terms>.
|
|
|
|
|
2011-12-19 03:38:24 +01:00
|
|
|
The messages will be grouped and sorted based on the threading (all
|
|
|
|
replies to a particular message will appear immediately after that
|
|
|
|
message in date order). The output is not indented by default, but
|
|
|
|
depth tags are printed so that proper indentation can be performed by
|
|
|
|
a post-processor (such as the emacs interface to notmuch).
|
|
|
|
|
|
|
|
Supported options for
|
|
|
|
.B show
|
|
|
|
include
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
2012-07-24 20:57:57 +02:00
|
|
|
.B \-\-entire\-thread=(true|false)
|
2011-12-19 03:38:24 +01:00
|
|
|
|
2012-07-24 20:57:57 +02:00
|
|
|
If true,
|
|
|
|
.B notmuch show
|
|
|
|
outputs all messages in the thread of any message matching the search
|
|
|
|
terms; if false, it outputs only the matching messages. For
|
|
|
|
.B --format=json
|
2012-12-06 22:12:15 +01:00
|
|
|
and
|
|
|
|
.B --format=sexp
|
2012-07-24 20:57:57 +02:00
|
|
|
this defaults to true. For other formats, this defaults to false.
|
2011-12-19 03:38:24 +01:00
|
|
|
.RE
|
|
|
|
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
2012-12-06 22:12:15 +01:00
|
|
|
.B \-\-format=(text|json|sexp|mbox|raw)
|
2011-12-19 03:38:24 +01:00
|
|
|
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.BR text " (default for messages)"
|
|
|
|
|
|
|
|
The default plain-text format has all text-content MIME parts
|
|
|
|
decoded. Various components in the output,
|
|
|
|
.RB ( message ", " header ", " body ", " attachment ", and MIME " part ),
|
|
|
|
will be delimited by easily-parsed markers. Each marker consists of a
|
|
|
|
Control-L character (ASCII decimal 12), the name of the marker, and
|
|
|
|
then either an opening or closing brace, ('{' or '}'), to either open
|
|
|
|
or close the component. For a multipart MIME message, these parts will
|
|
|
|
be nested.
|
|
|
|
.RE
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B json
|
|
|
|
|
|
|
|
The output is formatted with Javascript Object Notation (JSON). This
|
|
|
|
format is more robust than the text format for automated
|
|
|
|
processing. The nested structure of multipart MIME messages is
|
2012-07-24 20:57:57 +02:00
|
|
|
reflected in nested JSON output. By default JSON output includes all
|
|
|
|
messages in a matching thread; that is, by default,
|
2012-12-06 22:12:15 +01:00
|
|
|
|
2011-12-19 03:38:24 +01:00
|
|
|
.B \-\-format=json
|
2012-07-24 20:57:57 +02:00
|
|
|
sets
|
|
|
|
.B "\-\-entire\-thread"
|
|
|
|
The caller can disable this behaviour by setting
|
|
|
|
.B \-\-entire\-thread=false
|
2012-12-06 22:12:15 +01:00
|
|
|
.RE
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B sexp
|
|
|
|
|
|
|
|
The output is formatted as an S-Expression (sexp). This
|
|
|
|
format is more robust than the text format for automated
|
|
|
|
processing. The nested structure of multipart MIME messages is
|
|
|
|
reflected in nested S-Expression output. By default,
|
|
|
|
S-Expression output includes all messages in a matching thread;
|
|
|
|
that is, by default,
|
|
|
|
|
|
|
|
.B \-\-format=sexp
|
|
|
|
sets
|
|
|
|
.B "\-\-entire\-thread"
|
|
|
|
The caller can disable this behaviour by setting
|
|
|
|
.B \-\-entire\-thread=false
|
2011-12-19 03:38:24 +01:00
|
|
|
|
|
|
|
.RE
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B mbox
|
|
|
|
|
|
|
|
All matching messages are output in the traditional, Unix mbox format
|
|
|
|
with each message being prefixed by a line beginning with "From " and
|
|
|
|
a blank line separating each message. Lines in the message content
|
|
|
|
beginning with "From " (preceded by zero or more '>' characters) have
|
|
|
|
an additional '>' character added. This reversible escaping
|
|
|
|
is termed "mboxrd" format and described in detail here:
|
|
|
|
|
|
|
|
.nf
|
|
|
|
.nh
|
|
|
|
http://homepage.ntlworld.com/jonathan.deboynepollard/FGA/mail-mbox-formats.html
|
|
|
|
.hy
|
|
|
|
.fi
|
|
|
|
.
|
|
|
|
.RE
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.BR raw " (default for a single part, see \-\-part)"
|
|
|
|
|
2012-03-06 19:48:44 +01:00
|
|
|
For a message or an attached message part, the original, raw content
|
|
|
|
of the email message is output. Consumers of this format should expect
|
|
|
|
to implement MIME decoding and similar functions.
|
2011-12-19 03:38:24 +01:00
|
|
|
|
|
|
|
For a single part (\-\-part) the raw part content is output after
|
2012-03-06 19:48:44 +01:00
|
|
|
performing any necessary MIME decoding. Note that messages with a
|
|
|
|
simple body still have two parts: part 0 is the whole message and part
|
|
|
|
1 is the body.
|
|
|
|
|
|
|
|
For a multipart part, the part headers and body (including all child
|
|
|
|
parts) is output.
|
2011-12-19 03:38:24 +01:00
|
|
|
|
|
|
|
The raw format must only be used with search terms matching single
|
|
|
|
message.
|
|
|
|
.RE
|
|
|
|
.RE
|
|
|
|
|
2012-12-16 04:17:25 +01:00
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.BR \-\-format-version=N
|
|
|
|
|
|
|
|
Use the specified structured output format version. This is intended
|
|
|
|
for programs that invoke \fBnotmuch\fR(1) internally. If omitted, the
|
|
|
|
latest supported version will be used.
|
|
|
|
.RE
|
|
|
|
|
2011-12-19 03:38:24 +01:00
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B \-\-part=N
|
|
|
|
|
|
|
|
Output the single decoded MIME part N of a single message. The search
|
|
|
|
terms must match only a single message. Message parts are numbered in
|
|
|
|
a depth-first walk of the message MIME structure, and are identified
|
2012-12-06 22:12:15 +01:00
|
|
|
in the 'json', 'sexp' or 'text' output formats.
|
2011-12-19 03:38:24 +01:00
|
|
|
.RE
|
|
|
|
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B \-\-verify
|
|
|
|
|
|
|
|
Compute and report the validity of any MIME cryptographic signatures
|
|
|
|
found in the selected content (ie. "multipart/signed" parts). Status
|
|
|
|
of the signature will be reported (currently only supported with
|
2012-12-06 22:12:15 +01:00
|
|
|
--format=json and --format=sexp), and the multipart/signed part
|
|
|
|
will be replaced by the signed data.
|
2011-12-19 03:38:24 +01:00
|
|
|
.RE
|
|
|
|
|
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B \-\-decrypt
|
|
|
|
|
|
|
|
Decrypt any MIME encrypted parts found in the selected content
|
|
|
|
(ie. "multipart/encrypted" parts). Status of the decryption will be
|
2012-12-06 22:12:15 +01:00
|
|
|
reported (currently only supported with --format=json and
|
2013-03-01 17:43:26 +01:00
|
|
|
--format=sexp) and on successful decryption the multipart/encrypted
|
|
|
|
part will be replaced by the decrypted content.
|
|
|
|
|
|
|
|
Decryption expects a functioning \fBgpg-agent\fR(1) to provide any
|
|
|
|
needed credentials. Without one, the decryption will fail.
|
|
|
|
|
|
|
|
Implies --verify.
|
2011-12-19 03:38:24 +01:00
|
|
|
.RE
|
|
|
|
|
2012-03-01 23:30:42 +01:00
|
|
|
.RS 4
|
|
|
|
.TP 4
|
2012-04-07 18:10:06 +02:00
|
|
|
.BR \-\-exclude=(true|false)
|
|
|
|
|
|
|
|
Specify whether to omit threads only matching search.tag_exclude from
|
|
|
|
the search results (the default) or not. In either case the excluded
|
|
|
|
message will be marked with the exclude flag (except when output=mbox
|
|
|
|
when there is nowhere to put the flag).
|
|
|
|
|
|
|
|
If --entire-thread is specified then complete threads are returned
|
|
|
|
regardless (with the excluded flag being set when appropriate) but
|
|
|
|
threads that only match in an excluded message are not returned when
|
|
|
|
.B --exclude=true.
|
|
|
|
|
|
|
|
The default is
|
|
|
|
.B --exclude=true.
|
2012-03-01 23:30:42 +01:00
|
|
|
|
|
|
|
.RE
|
|
|
|
|
2012-07-24 20:23:29 +02:00
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B \-\-body=(true|false)
|
|
|
|
|
|
|
|
If true (the default)
|
|
|
|
.B notmuch show
|
|
|
|
includes the bodies of the messages in the output; if false,
|
|
|
|
bodies are omitted.
|
|
|
|
.B --body=false
|
2012-12-06 22:12:15 +01:00
|
|
|
is only implemented for the json and sexp formats and it is incompatible with
|
2012-07-24 20:23:29 +02:00
|
|
|
.B --part > 0.
|
|
|
|
|
|
|
|
This is useful if the caller only needs the headers as body-less
|
|
|
|
output is much faster and substantially smaller.
|
|
|
|
.RE
|
|
|
|
|
2013-07-02 02:19:42 +02:00
|
|
|
.RS 4
|
|
|
|
.TP 4
|
|
|
|
.B \-\-include-html
|
|
|
|
|
|
|
|
Include "text/html" parts as part of the output (currently only supported with
|
|
|
|
--format=json and --format=sexp).
|
|
|
|
By default, unless
|
|
|
|
.B --part=N
|
|
|
|
is used to select a specific part or
|
|
|
|
.B --include-html
|
|
|
|
is used to include all "text/html" parts, no part with content type "text/html"
|
|
|
|
is included in the output.
|
|
|
|
.RE
|
|
|
|
|
2011-12-19 03:38:24 +01:00
|
|
|
A common use of
|
|
|
|
.B notmuch show
|
|
|
|
is to display a single thread of email messages. For this, use a
|
|
|
|
search term of "thread:<thread-id>" as can be seen in the first
|
|
|
|
column of output from the
|
|
|
|
.B notmuch search
|
|
|
|
command.
|
|
|
|
|
2012-12-16 04:17:25 +01:00
|
|
|
.SH EXIT STATUS
|
|
|
|
|
|
|
|
This command supports the following special exit status codes
|
|
|
|
|
|
|
|
.TP
|
|
|
|
.B 20
|
|
|
|
The requested format version is too old.
|
|
|
|
.TP
|
|
|
|
.B 21
|
|
|
|
The requested format version is too new.
|
|
|
|
|
2011-12-20 02:41:48 +01:00
|
|
|
.SH SEE ALSO
|
|
|
|
|
|
|
|
\fBnotmuch\fR(1), \fBnotmuch-config\fR(1), \fBnotmuch-count\fR(1),
|
2013-06-23 06:23:58 +02:00
|
|
|
\fBnotmuch-dump\fR(1), \fBnotmuch-hooks\fR(5),
|
|
|
|
\fBnotmuch-insert\fR(1), \fBnotmuch-new\fR(1),
|
2012-03-11 22:36:16 +01:00
|
|
|
\fBnotmuch-reply\fR(1), \fBnotmuch-restore\fR(1),
|
|
|
|
\fBnotmuch-search\fR(1), \fBnotmuch-search-terms\fR(7),
|
|
|
|
\fBnotmuch-tag\fR(1)
|