5 notmuch - thread-based email index, search, and tagging
10 <b>notmuch</b> [option ...] <b>command</b> [arg ...]
15 Notmuch is a command-line based program for indexing, searching, read‐
16 ing, and tagging large collections of email messages.
18 This page describes how to get started using notmuch from the command
19 line, and gives a brief overview of the commands available. For more
20 information on e.g. <b>notmuch</b> <b>show</b> consult the <a href='../notmuch-show-1/'>notmuch-show</a>(1) man page,
21 also accessible via <b>notmuch</b> <b>help</b> <b>show</b>
23 The quickest way to get started with Notmuch is to simply invoke the
24 <b>notmuch</b> command with no arguments, which will interactively guide you
25 through the process of indexing your mail.
30 While the command-line program <b>notmuch</b> provides powerful functionality,
31 it does not provide the most convenient interface for that functional‐
32 ity. More sophisticated interfaces are expected to be built on top of
33 either the command-line interface, or more likely, on top of the not‐
34 much library interface. See <u>https://notmuchmail.org</u> for more about al‐
35 ternate interfaces to notmuch. The emacs-based interface to notmuch
36 (available under <b>emacs/</b> in the Notmuch source distribution) is probably
37 the most widely used at this time.
42 Supported global options for <b>notmuch</b> include
44 <b>--help</b> <b>[command-name]</b>
45 Print a synopsis of available commands and exit. With an op‐
46 tional command name, show the man page for that subcommand.
49 Print the installed version of notmuch, and exit.
52 Specify the configuration file to use. This overrides any con‐
53 figuration file specified by ${NOTMUCH_CONFIG}. The empty string
54 is a permitted and sometimes useful value of <u>FILE</u>, which tells
55 <b>notmuch</b> to use only configuration metadata from the database.
58 Enforce that the database UUID (a unique identifier which per‐
59 sists until e.g. the database is compacted) is HEX; exit with an
60 error if it is not. This is useful to detect rollover in modifi‐
61 cation counts on messages. You can find this UUID using e.g.
62 <b>notmuch</b> <b>count</b> <b>--lastmod</b>
64 All global options except <b>--config</b> can also be specified after the com‐
65 mand. For example, <b>notmuch</b> <b>subcommand</b> <b>--uuid=HEX</b> is equivalent to <b>not-</b>
66 <b>much</b> <b>--uuid=HEX</b> <b>subcommand</b>.
71 <h3> SETUP</h3>
73 The <b>notmuch</b> <b>setup</b> command is used to configure Notmuch for first use,
74 (or to reconfigure it later).
76 The setup command will prompt for your full name, your primary email
77 address, any alternate email addresses you use, and the directory con‐
78 taining your email archives. Your answers will be written to a configu‐
79 ration file in ${NOTMUCH_CONFIG} (if set) or ${HOME}/.notmuch-config .
80 This configuration file will be created with descriptive comments, mak‐
81 ing it easy to edit by hand later to change the configuration. Or you
82 can run <b>notmuch</b> <b>setup</b> again to change the configuration.
84 The mail directory you specify can contain any number of sub-directo‐
85 ries and should primarily contain only files with individual email mes‐
86 sages (eg. maildir or mh archives are perfect). If there are other,
87 non-email files (such as indexes maintained by other email programs)
88 then notmuch will do its best to detect those and ignore them.
90 Mail storage that uses mbox format, (where one mbox file contains many
91 messages), will not work with notmuch. If that's how your mail is cur‐
92 rently stored, it is recommended you first convert it to maildir format
93 with a utility such as mb2md before running <b>notmuch</b> <b>setup</b> <b>.</b>
95 Invoking <b>notmuch</b> with no command argument will run <b>setup</b> if the setup
96 command has not previously been completed.
99 <h3> OTHER COMMANDS</h3>
101 Several of the notmuch commands accept search terms with a common syn‐
102 tax. See <b>notmuch-search-terms</b>(7) for more details on the supported syn‐
105 The <b>search</b>, <b>show</b>, <b>address</b> and <b>count</b> commands are used to query the
108 The <b>reply</b> command is useful for preparing a template for an email re‐
111 The <b>tag</b> command is the only command available for manipulating database
114 The <b>dump</b> and <b>restore</b> commands can be used to create a textual dump of
115 email tags for backup purposes, and to restore from that dump.
117 The <b>config</b> command can be used to get or set settings in the notmuch
121 <h3> CUSTOM COMMANDS</h3>
123 If the given command is not known to notmuch, notmuch tries to execute
124 the external <b>notmuch-<subcommand></b> in ${PATH} instead. This allows users
125 to have their own notmuch related tools to be run via the notmuch com‐
126 mand. By design, this does not allow notmuch's own commands to be over‐
127 ridden using external commands.
130 <h3> OPTION SYNTAX</h3>
132 All options accepting an argument can be used with '=' or ':' as a sep‐
133 arator. Except for boolean options (which would be ambiguous), a space
134 can also be used as a separator. The following are all equivalent:
136 notmuch --config=alt-config config get user.name
137 notmuch --config:alt-config config get user.name
138 notmuch --config alt-config config get user.name
143 The following environment variables can be used to control the behavior
146 <b>NOTMUCH</b>_<b>CONFIG</b>
147 Specifies the location of the notmuch configuration file. Not‐
148 much will use ${HOME}/.notmuch-config if this variable is not
151 <b>NOTMUCH</b>_<b>TALLOC</b>_<b>REPORT</b>
152 Location to write a talloc memory usage report. See <b>talloc</b>_<b>en-</b>
153 <b>able</b>_<b>leak</b>_<b>report</b>_<b>full</b> in <b>talloc</b>(3) for more information.
155 <b>NOTMUCH</b>_<b>DEBUG</b>_<b>QUERY</b>
156 If set to a non-empty value, the notmuch library will print (to
157 stderr) Xapian queries it constructs.
162 <a href='../notmuch-address-1/'>notmuch-address</a>(1), <a href='../notmuch-compact-1/'>notmuch-compact</a>(1), <a href='../notmuch-config-1/'>notmuch-config</a>(1), <a href='../notmuch-count-1/'>not‐</a>
163 <a href='../notmuch-count-1/'>much-count</a>(1), <a href='../notmuch-dump-1/'>notmuch-dump</a>(1), <a href='../notmuch-hooks-5/'>notmuch-hooks</a>(5), <a href='../notmuch-insert-1/'>notmuch-insert</a>(1),
164 <a href='../notmuch-new-1/'>notmuch-new</a>(1), <a href='../notmuch-properties-7/'>notmuch-properties</a>(7), <a href='../notmuch-reindex-1/'>notmuch-reindex</a>(1), <a href='../notmuch-reply-1/'>notmuch-re‐</a>
165 <a href='../notmuch-reply-1/'>ply</a>(1), <a href='../notmuch-restore-1/'>notmuch-restore</a>(1), <a href='../notmuch-search-1/'>notmuch-search</a>(1), <a href='../notmuch-search-terms-7/'>notmuch-search-terms</a>(7),
166 <a href='../notmuch-show-1/'>notmuch-show</a>(1), <a href='../notmuch-tag-1/'>notmuch-tag</a>(1)
168 The notmuch website: <b>https://notmuchmail.org</b>
173 Feel free to send questions, comments, or kudos to the notmuch mailing
174 list <<u>notmuch@notmuchmail.org</u>> . Subscription is not required before
175 posting, but is available from the notmuchmail.org website.
177 Real-time interaction with the Notmuch community is available via IRC
178 (server: irc.libera.net, channel: #notmuch).
183 Carl Worth and many others
188 2009-2021, Carl Worth and many others