Notmuch 0.13 (2012-05-15)
Command-Line Interface
JSON reply format
notmuch reply
can now produce JSON output that contains the headers
for a reply message and full information about the original message
begin replied to. This allows MUAs to create replies intelligently.
For example, an MUA that can parse HTML might quote HTML parts.
Calling notmuch reply with --format=json
imposes the restriction that
only a single message is returned by the search, as replying to
multiple messages does not have a well-defined behavior. The default
retains its current behavior for multiple message replies.
Tag exclusion
Tags can be automatically excluded from search results by adding them
to the new search.exclude_tags
option in the Notmuch config file.
This behaviour can be overridden by explicitly including an excluded tag in your query, for example:
notmuch search $your_query and tag:$excluded_tag
Existing users will probably want to run notmuch setup
again to add
the new well-commented [search] section to the configuration file.
For new configurations, accepting the default setting will cause the tags "deleted" and "spam" to be excluded, equivalent to running:
notmuch config set search.exclude_tags deleted spam
Raw show format changes
The output of show --format=raw
has changed for multipart and
message parts. Previously, the output was a mash of somewhat-parsed
headers and transfer-decoded bodies. Now, such parts are reproduced
faithfully from the original source. Message parts (which includes
part 0) output the full message, including the message headers (but
not the transfer headers). Multipart parts output the part as
encoded in the original message, including the part's headers. Leaf
parts, as before, output the part's transfer-decoded body.
Listing configuration items
The new config list
command prints out all configuration items and
their values.
Emacs Interface
Changes to tagging interface
The user-facing tagging functions in the Emacs interface have been normalized across all notmuch modes. The tagging functions are now notmuch-search-tag in search-mode, and notmuch-show-tag in show-mode. They accept a string representing a single tag change, or a list of tag changes. See 'M-x describe-function notmuch-tag' for more information.
NOTE: This breaks compatibility with old tagging functions, so user may need to update in custom configurations.
Reply improvement using the JSON format
Emacs now uses the JSON reply format to create replies. It obeys the customization variables message-citation-line-format and message-citation-line-function when creating the first line of the reply body, and it will quote HTML parts if no text/plain parts are available.
New add-on tool: notmuch-mutt
The new contrib/ tool notmuch-mutt
provides Notmuch integration for
the Mutt mail user agent. Using it, Mutt users can perform mail
search, thread reconstruction, and mail tagging/untagging without
leaving Mutt. notmuch-mutt, formerly distributed under the name
mutt-notmuch
by Stefano Zacchiroli, will be maintained as a notmuch
contrib/ from now on.
Library changes
The API changes detailed below break binary and source compatibility, so libnotmuch has been bumped to version 3.0.0.
The function notmuch_database_close
has been split into notmuch_database_close
and notmuch_database_destroy
This makes it possible for long running programs to close the xapian database and thus release the lock associated with it without destroying the data structures obtained from it.
notmuch_database_open
, notmuch_database_create
, and notmuch_database_get_directory
now return errors
The type signatures of these functions have changed so that the
functions now return a notmuch_status_t
and take an out-argument for
returning the new database object or directory object.
Go bindings changes
Go 1 compatibility
The go bindings and the notmuch-addrlookup
utility are now
compatible with go 1.