notmuch.git
11 years agoemacs: Streaming S-expression parser
Austin Clements [Sat, 1 Jun 2013 00:40:06 +0000 (20:40 -0400)]
emacs: Streaming S-expression parser

This provides the same interface as the streaming JSON parser, but
reads S-expressions incrementally.  The only difference is that the
`notmuch-sexp-parse-partial-list' helper does not handle interleaved
error messages (since we now have the ability to separate these out at
the invocation level), so it no longer takes an error function and
does not need to do the horrible resynchronization that the JSON
parser had to.

Some implementation improvements have been made over the JSON parser.
This uses a vector instead of a list for the parser data structure,
since this allows faster access to elements (and modern versions of
Emacs handle storage of small vectors efficiently).  Private functions
follow the "prefix--name" convention.  And the implementation is much
simpler overall because S-expressions are much easier to parse.

11 years agoemacs: Use async process helper for search
Austin Clements [Sat, 1 Jun 2013 00:40:05 +0000 (20:40 -0400)]
emacs: Use async process helper for search

Previously, search started the async notmuch process directly.  Now,
it uses `notmuch-start-notmuch'.  This simplifies the process sentinel
a bit and means that we no longer have to worry about errors
interleaved with the JSON output.

We also update the tests of Emacs error handling, since the error
output is now separated from the search results buffer.

11 years agoemacs: Utilities to manage asynchronous notmuch processes
Austin Clements [Sat, 1 Jun 2013 00:40:04 +0000 (20:40 -0400)]
emacs: Utilities to manage asynchronous notmuch processes

This provides a new notmuch-lib utility to start an asynchronous
notmuch process that handles redirecting of stderr and checking of the
exit status.  This is similar to `notmuch-call-notmuch-json', but for
asynchronous processes (and it leaves output processing to the
caller).

11 years agotest: Remove extraneous Emacs error handling test
Austin Clements [Sat, 1 Jun 2013 00:40:03 +0000 (20:40 -0400)]
test: Remove extraneous Emacs error handling test

We now check error handling more carefully in the last test in
test/emacs and we're about to add more error handling tests.  (This
was also a strange place for this test, since it had nothing to do
with large search buffers.)

11 years agoNews for Emacs part handling changes
Austin Clements [Thu, 30 May 2013 01:13:48 +0000 (21:13 -0400)]
News for Emacs part handling changes

11 years agoemacs: Bind MIME part commands to "." submap
Austin Clements [Thu, 30 May 2013 01:13:47 +0000 (21:13 -0400)]
emacs: Bind MIME part commands to "." submap

Since the part commands are no longer tied to a button, but can be
applied with point anywhere within a part, bind the part commands
keymap to "." everywhere in the show buffer.  This lets you save or
view parts without having to navigate to the part button, and is
particularly useful for parts that have no button.

This removes the un-prefixed MIME part commands from the part button
keymap, but that's okay because those clashed in annoying ways with
show buffer bindings like "s" for search.  RET on part buttons is
unaffected, which is the most important part button binding.

11 years agoemacs: Simplify MIME part command implementation
Austin Clements [Thu, 30 May 2013 01:13:46 +0000 (21:13 -0400)]
emacs: Simplify MIME part command implementation

This unifies the part button actions and the underlying part action
functions into single interactive command that simply applies to the
part containing point using the just-added part p-list text property
instead of button properties.  Since all part actions can be performed
by applying the appropriate mm function to an mm-handle, this patch
abstracts out the creation of mm handles, making the implementations
of the part commands trivial.  This also eliminates our special
handling for part save in favor of using the appropriate mm function.

This necessarily modifies the way we handle the default part button
action, but in a way that does not change the meaning of the
notmuch-show-part-button-default-action defcustom.

Since these commands are no longer specific to buttons, this patch
eliminates the extra metadata stored with each button.  This also
eliminates one rather special-purpose macro for a collection of
general purpose part handling utilities.

11 years agoemacs: Record part p-list in a text property
Austin Clements [Thu, 30 May 2013 01:13:45 +0000 (21:13 -0400)]
emacs: Record part p-list in a text property

This is similar to what we already do with the message p-list, though
we apply the part's text property to the whole part's text, in
contrast with the message p-list, which is (rather obscurely) only
applied to the first character.

11 years agoemacs: Retain text properties when toggling buttons
Austin Clements [Thu, 30 May 2013 01:13:44 +0000 (21:13 -0400)]
emacs: Retain text properties when toggling buttons

Previously, we lost any text properties applied to part buttons or
wash buttons when they were toggled because `insert' directly copies
the text properties of the string being inserted.  Fix this by
capturing the properties applied to the button beforehand and
re-applying them after inserting the new text.

11 years agoTODO: keybindings for next/previous thread done
Jani Nikula [Sat, 25 May 2013 12:14:26 +0000 (15:14 +0300)]
TODO: keybindings for next/previous thread done

11 years agocli: remove unused argument descriptions
Jani Nikula [Sat, 25 May 2013 11:09:13 +0000 (14:09 +0300)]
cli: remove unused argument descriptions

Clean up leftovers from help system rework. These are no longer
needed. They are easy to resurrect and update if a need later arises.

11 years agoNEWS: added information about new --stderr=FILE top level option
Tomi Ollila [Tue, 28 May 2013 18:38:55 +0000 (21:38 +0300)]
NEWS: added information about new --stderr=FILE top level option

11 years agoman: documented --stderr=FILE in notmuch.1 manual page
Tomi Ollila [Tue, 28 May 2013 18:38:54 +0000 (21:38 +0300)]
man: documented --stderr=FILE in notmuch.1 manual page

11 years agotest: added --stderr=FILE tests
Tomi Ollila [Tue, 28 May 2013 18:38:53 +0000 (21:38 +0300)]
test: added --stderr=FILE tests

--stderr=FILE tests were added to test/help-test as it is the one
doing most global option testing. Also, it was simplest to test
this new option using `notmuch help` command.

11 years agocli: add global option --stderr=FILE
Tomi Ollila [Tue, 28 May 2013 18:38:52 +0000 (21:38 +0300)]
cli: add global option --stderr=FILE

With this option all writes to stderr are redirected to the specified
FILE (or to stdout on case FILE is '-'). This is immediately useful
in emacs interface as some of its exec intefaces do not provide
separation of stdout and stderr.

11 years agoemacs: Fix trimming regexp in notmuch-check-exit-status
Austin Clements [Fri, 17 May 2013 20:14:03 +0000 (16:14 -0400)]
emacs: Fix trimming regexp in notmuch-check-exit-status

For such a simple regexp, this was broken in a very complicated way.

The intent was to strip the newline (and potentially other whitespace)
off the end of the error string so there wasn't an extra newline in
the error signal.  However, the regexp was deeply dependent on the
active syntax table and the subtleties of $.  We didn't notice this
because all notmuch major modes put ?\n in the whitespace class, which
makes this behaved as intended: the "\\s " matches all newlines, but
by matching the newline character, causes the $ *not* to match
*except* where it matched the empty string at the very end of the
string, which was not followed by a newline.

However, if the syntax table declares ?\n to be non-whitespace
(lisp-mode declares it as endcomment, and is likely to be the mode
you're in when testing functions), then this regexp behaves completely
differently, matching trailing spaces at the end of every line within
the string.

The solution is to say what we mean for whitespace *and* to switch
from $ to \', which matches only the end of the string, rather than
the end of each line.  Both are necessary or this will strip away
interior newlines, which is not what we want.

11 years agobuild: fix out-of-tree builds
Jani Nikula [Sat, 25 May 2013 11:18:58 +0000 (14:18 +0300)]
build: fix out-of-tree builds

Support for out-of-tree builds was added in
commit 3e4a9d60a9419621b08c647a306843d76c47c2cb
Author: Carl Worth <cworth@cworth.org>
Date:   Wed Mar 9 15:02:42 2011 -0800

    build: Add support for non-source-directory builds.

and broken in
commit 7beeb8c88a014ecbc53d8241f10683b3c4c16228
Author: David Bremner <bremner@debian.org>
Date:   Sat Nov 17 12:28:15 2012 -0400

    test: initial performance testing infrastructure

Fix the build breakage.

Out-of-tree 'make test' has been broken since earlier than the above,
and remains broken, as does out-of-tree perf test, but at least the
build now works.

11 years agoemacs: add show view bindings to move to previous/next thread
Jani Nikula [Sat, 25 May 2013 21:13:30 +0000 (22:13 +0100)]
emacs: add show view bindings to move to previous/next thread

We have most of the plumbing in place, add the bindings M-n and M-p.

11 years agoemacs: Don't override mm-show-part in notmuch-show-view-part
Austin Clements [Sun, 26 May 2013 06:34:46 +0000 (02:34 -0400)]
emacs: Don't override mm-show-part in notmuch-show-view-part

Previously, notmuch-show-view-part overrode the function binding of
mm-show-part to redirect it to notmuch-show-save-part to get notmuch's
default file name handling in case mm-display-part decided to fall
back to saving the part.  In addition to being messy, this depended on
the now-deprecated dynamic binding behavior of flet.

This patch removes the mm-show-part override in favor of passing the
file name in to mm-show-part the way it expects, so we get its default
file name handling.  It's not clear why we didn't do this before;
mm-show-part has supported default file names since at least Emacs
23.1.

11 years agoNEWS: a bunch of cli news since 0.15
Jani Nikula [Sun, 26 May 2013 18:51:58 +0000 (21:51 +0300)]
NEWS: a bunch of cli news since 0.15

11 years agoMerge branch 'release'
David Bremner [Sun, 26 May 2013 00:20:39 +0000 (21:20 -0300)]
Merge branch 'release'

merge back debian-only release into master

11 years agodebian: bump standards version to 3.9.4 debian/0.15.2-2
David Bremner [Sat, 25 May 2013 21:37:48 +0000 (18:37 -0300)]
debian: bump standards version to 3.9.4

11 years agoNEWS: No Emacs 22 support
Tomi Ollila [Tue, 21 May 2013 17:07:13 +0000 (20:07 +0300)]
NEWS: No Emacs 22 support

11 years agodebian: package ruby bindings
Felipe Contreras [Tue, 16 Apr 2013 19:08:39 +0000 (14:08 -0500)]
debian: package ruby bindings

Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
11 years agoruby: use in-tree notmuch library
Felipe Contreras [Mon, 20 May 2013 12:24:23 +0000 (07:24 -0500)]
ruby: use in-tree notmuch library

Currently it simply finds any library available, and if notmuch is
installed in the system, it would give priority to that library.

Let's implement our own helper functions to link directly to the local
library, and give priority to the local header file.

Also, add an option to properly check if there are missing symbols.

Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
11 years agoemacs: Compute build dependencies to fix byte compile issues
Austin Clements [Fri, 17 May 2013 20:13:31 +0000 (16:13 -0400)]
emacs: Compute build dependencies to fix byte compile issues

Previously, we simply byte compiled each Elisp source file
independently.  This is actually the wrong thing to do and can lead to
issues with macros and performance issues with substitutions because
1) when the byte compiler encounters a (require 'x) form, it will load
x.elc in preference to x.el, even if x.el is newer, and as a result
may load old macro and substitution definitions and 2) if we update a
macro or substitution definition in one file, we currently won't
re-compile other files that depend on the file containing the
definition.

This patch addresses these problems by computing make dependency rules
from the (require 'x) forms in the Elisp source files, which we inject
into make's dependency database.

11 years agoruby: fix missing symbol UINT2FIX()
Felipe Contreras [Mon, 20 May 2013 12:24:24 +0000 (07:24 -0500)]
ruby: fix missing symbol UINT2FIX()

It has never existed in Ruby (maybe JRuby). Fortunately the symbols are
loaded lazily, so nobody would notice unless they try
'query::count_messages'.

Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
11 years agodevel: add dkg's printmimestructure script to notmuch devel scripts
David Bremner [Mon, 20 May 2013 15:59:19 +0000 (12:59 -0300)]
devel: add dkg's printmimestructure script to notmuch devel scripts

I find this script pretty useful when figuring out who to blame for
MIME rendering problems.

The notmuch repo will be the new primary home for this script, unless
and until a better home turns up.

11 years agocontrib: pick: add a target message for pick
Mark Walters [Thu, 10 Jan 2013 11:14:58 +0000 (11:14 +0000)]
contrib: pick: add a target message for pick

This adds a target message for pick which it will jump to when (if) it
appears. It adds the target to notmuch-pick-from-show-current-query so
that pick goes straight to the message that was current in the show
view and it adds target to notmuch-pick-refresh-view so that the
current message is preserved.

11 years agocontrib: pick: move save-excursion closer to message insertion
Mark Walters [Thu, 10 Jan 2013 10:41:16 +0000 (10:41 +0000)]
contrib: pick: move save-excursion closer to message insertion

Pick keeps point roughly at the top of the buffer while inserting
messages at the end as they come in (from the async
parser). Previously the save-excursion to do this was done once for
each thread inserted: now it is done for each individual message.

The advantage is that the message insertion code can decide where to
leave point. In the next patch point will be left on the target message.

Note notmuch-pick-insert-msg is unchanged as that is used by the tag
display update code.

11 years agoemacs: show: handle inline patch fake parts at top level
Mark Walters [Sat, 4 May 2013 13:01:15 +0000 (14:01 +0100)]
emacs: show: handle inline patch fake parts at top level

The inline patch fake part handler also modifies the content-type so
handle this in notmuch-show-insert-bodypart too.

11 years agoemacs:show: separate out handling of application/octet-stream
Mark Walters [Sat, 4 May 2013 13:01:14 +0000 (14:01 +0100)]
emacs:show: separate out handling of application/octet-stream

Currently mime parts are basically handled based on their mime-type
with the exception of application/octet-stream parts. Deal with these
parts at the top level (notmuch-show-insert-bodypart).

This is needed later in the series as we need to put in a part button
for each part (which means knowing its mime type) while deferring the
actual insertion of the part.

11 years agoemacs: Proper error string handling in search sentinel
Austin Clements [Fri, 17 May 2013 20:14:28 +0000 (16:14 -0400)]
emacs: Proper error string handling in search sentinel

Apparently Emacs provides a function to stringify errors properly.
Use this in the search sentinel where we have to do our own error
messaging, rather than assuming the first error argument will be the
descriptive string.

11 years agoemacs: tag: fix compile warning
Mark Walters [Tue, 14 May 2013 08:13:53 +0000 (09:13 +0100)]
emacs: tag: fix compile warning

When compiling notmuch-tag.el there is a compile warning:
notmuch-tag.el:27:1:Warning: cl package required at runtime

Since we have decided to allow runtime use of cl we suppress this
warning by adding a tail comment to the file.

11 years agoperf-test: add notmuch-memory-test
David Bremner [Wed, 15 May 2013 10:53:27 +0000 (07:53 -0300)]
perf-test: add notmuch-memory-test

Somehow this file was not added to the patch set which split the tests
into time and memory tests. Take advantage of the the "new" way of
running tests to avoid listing the explicitly.

11 years agoperf-test: run all appropriately named time tests
David Bremner [Wed, 15 May 2013 10:48:30 +0000 (07:48 -0300)]
perf-test: run all appropriately named time tests

This avoids hassle with manually adding every test to the master list.

11 years agoperf-test: rename time tests to have .sh suffix
David Bremner [Wed, 15 May 2013 10:40:08 +0000 (07:40 -0300)]
perf-test: rename time tests to have .sh suffix

This will simplify notmuch time tests

11 years agoperf-test: rename memory tests
David Bremner [Wed, 15 May 2013 10:38:09 +0000 (07:38 -0300)]
perf-test: rename memory tests

The common suffix will help running them all automatically.

11 years agoman: document search --exclude=all
Peter Wang [Sat, 11 May 2013 19:50:07 +0000 (20:50 +0100)]
man: document search --exclude=all

Document the new search --exclude=all option.

11 years agotest: add tests for search --exclude=all
Peter Wang [Sat, 11 May 2013 19:50:04 +0000 (20:50 +0100)]
test: add tests for search --exclude=all

Test the new search --exclude=all option.

11 years agocli: add --exclude=all option to notmuch-search.c
Mark Walters [Sat, 11 May 2013 19:50:03 +0000 (20:50 +0100)]
cli: add --exclude=all option to notmuch-search.c

Add a --exclude=all option to notmuch search.

11 years agolib: add --exclude=all option
Mark Walters [Sat, 11 May 2013 19:50:02 +0000 (20:50 +0100)]
lib: add --exclude=all option

Adds a exclude all option to the lib which means that excluded
messages are completely ignored (as if they had actually been
deleted).

11 years agolib/database.cc: change how the parent of a message is calculated
Aaron Ecay [Wed, 6 Mar 2013 03:31:49 +0000 (22:31 -0500)]
lib/database.cc: change how the parent of a message is calculated

Presently, the code which finds the parent of a message as it is being
added to the database assumes that the first Message-ID-like substring
of the In-Reply-To header is the parent Message ID.  Some mail clients,
however, put stuff other than the Message-ID of the parent in the
In-Reply-To header, such as the email address of the sender of the
parent.  This can fool notmuch.

The updated algorithm prefers the last Message ID in the References
header.  The References header lists messages oldest-first, so the last
Message ID is the parent (RFC2822, p. 24).  The References header is
also less likely to be in a non-standard
syntax (http://cr.yp.to/immhf/thread.html,
http://www.jwz.org/doc/threading.html).  In case the References header
is not to be found, fall back to the old behavior.

V2 of this patch, incorporating feedback from Jani and (indirectly)
Austin.

11 years agotest: add tests for the handling of References and In-Reply-To headers
Aaron Ecay [Wed, 6 Mar 2013 03:31:48 +0000 (22:31 -0500)]
test: add tests for the handling of References and In-Reply-To headers

These tests are known_broken, the following commit fixes them.

amended per

id:87txmi1zq3.fsf@nikula.org
id:87vc6yalo7.fsf@zancas.localnet

11 years agoemacs: removed code attempting to support emaces prior to version 23
Tomi Ollila [Sun, 31 Mar 2013 20:04:02 +0000 (23:04 +0300)]
emacs: removed code attempting to support emaces prior to version 23

The support for emacs version 22 has not worked at least since
September 2011 when I attempted to use it. I expanded the support in
id:yf6ippgtbn0.fsf@taco2.nixu.fi but that was not enough and then I
found it easier to switch to emacs 23.
In case one wants to resurrect emacs 22 (or earlier!) support, pick
the changes from the patch email referenced above.

11 years agoemacs/notmuch-address.el: add notmuch-address-selection-function
Tomi Ollila [Wed, 3 Apr 2013 15:08:54 +0000 (18:08 +0300)]
emacs/notmuch-address.el: add notmuch-address-selection-function

Added a customizable variable notmuch-address-selection-function
and the function with the same name to provide a way for user to
change the function called to do address selection.

By default the functionality is exactly the same as it has been so
far; completing-read is called with the same parameters as before.

Setting equivalent lambda expression in place of using
notmuch-address-selection-function function is done as follows:

(setq notmuch-address-selection-function
   (lambda (prompt collection initial-input)
     (completing-read prompt collection nil nil initial-input)))

For example drop-in replacement with ido-completing-read can be done
easily as an one alternative to the default.

11 years agocli: config: fix config file save when the file does not exist
Jani Nikula [Sun, 5 May 2013 19:18:20 +0000 (22:18 +0300)]
cli: config: fix config file save when the file does not exist

The use of realpath(3) in
commit 58ed67992d0ec1fa505026105218fa449f7980b0
Author: Jani Nikula <jani@nikula.org>
Date:   Sun Apr 7 20:15:03 2013 +0300

    cli: config: do not overwrite symlinks when saving config file

broke config file save when the file does not exist, which results in
'notmuch setup' always failing to create a new config file.

Fix by checking ENOENT from realpath(3).

11 years agotest: add basic test for notmuch setup
Jani Nikula [Sun, 5 May 2013 19:18:19 +0000 (22:18 +0300)]
test: add basic test for notmuch setup

And annotate with test_subtest_known_broken. Hooray.

11 years agoman: clarify search --exclude=flag
Peter Wang [Sat, 11 May 2013 19:50:06 +0000 (20:50 +0100)]
man: clarify search --exclude=flag

Improve the description of the search --exclude=flag option,
using text taken from the commit that introduced the option.

11 years agoman: clarify search --exclude documentation
Peter Wang [Sat, 11 May 2013 19:50:05 +0000 (20:50 +0100)]
man: clarify search --exclude documentation

Highlight "excluded messages" as a term with a meaning that
may not be obvious.

Be explicit about the effects of search --exclude=true and
--exclude=false.

11 years agoemacs: add kernel.org mail archive redirector
Jani Nikula [Thu, 2 May 2013 13:15:07 +0000 (15:15 +0200)]
emacs: add kernel.org mail archive redirector

See http://lkml.kernel.org/

11 years agopython: Add bindings for notmuch_thread_get_messages
Austin Clements [Sun, 25 Nov 2012 04:57:06 +0000 (23:57 -0500)]
python: Add bindings for notmuch_thread_get_messages

11 years agogo: use a different goconfig package
Justus Winter [Tue, 23 Apr 2013 15:13:07 +0000 (17:13 +0200)]
go: use a different goconfig package

The notmuch-addrlookup utility uses a third party library to read the
notmuch configuration file. The previously used implementation at
"github.com/kless/goconfig" vanished, so this patch switches to the
implementation at "github.com/msbranco/goconfig". As the
implementations differ at the API level, the code is updated
accordingly.

Signed-off-by: Justus Winter <4winter@informatik.uni-hamburg.de>
11 years agolib/message.cc: stale pointer bug (v3)
Vladimir Marek [Thu, 2 May 2013 14:31:42 +0000 (16:31 +0200)]
lib/message.cc: stale pointer bug (v3)

Xapian::TermIterator::operator* returns std::string which is destroyed
as soon as (*i).c_str() finishes. The remembered pointer 'term' then
references invalid memory.

Signed-off-by: Vladimir Marek <vlmarek@volny.cz>
11 years agoemacs: fixed (declare-function ...) definitions
Tomi Ollila [Wed, 10 Apr 2013 21:42:55 +0000 (00:42 +0300)]
emacs: fixed (declare-function ...) definitions

Some (declare-function ...) definitions were drifted away from the
actual (defun ...)'s. To find the drifts and to verify changes
the following command line was used:

$ emacs --batch -L emacs --eval '(check-declare-directory "emacs")'

11 years agoman: document NOTMUCH_DEBUG_QUERY
David Bremner [Mon, 15 Apr 2013 14:26:36 +0000 (11:26 -0300)]
man: document NOTMUCH_DEBUG_QUERY

This is is really functionality of the library, but CLI users might
not look at library docs even if they existed beyond notmuch.h

11 years agocli: mime node: fix compiler warning when building against gmime 2.4
Jani Nikula [Sat, 6 Apr 2013 11:47:43 +0000 (14:47 +0300)]
cli: mime node: fix compiler warning when building against gmime 2.4

commit d487ef9e58bcd193118f19f771d5ef3984616be5
Author: Jani Nikula <jani@nikula.org>
Date:   Sat Mar 30 15:53:16 2013 +0200

    cli: mime node: abstract decryption and signature verification

introduced a compiler warning, reported by Mark Walters, when building
against gmime 2.4:

mime-node.c:224:9: warning: assignment discards â€˜const’ qualifier from
pointer target type [enabled by default]

Pass the non-const signature validity to the destructor to fix this.

11 years agoTODO: remove some completed todo items from the list
Jani Nikula [Sun, 7 Apr 2013 17:15:04 +0000 (20:15 +0300)]
TODO: remove some completed todo items from the list

Bash completion has been rewritten. Configuration file saves follow
symlinks. There is --config=FILE top level option to specify
configuration file.

11 years agocli: config: do not overwrite symlinks when saving config file
Jani Nikula [Sun, 7 Apr 2013 17:15:03 +0000 (20:15 +0300)]
cli: config: do not overwrite symlinks when saving config file

Use realpath to canonicalize the config path before writing.

Previously 'notmuch setup' and 'notmuch config set' overwrote the
config file even if it was a symbolic link.

11 years agotest: add some config file tests
Jani Nikula [Sun, 7 Apr 2013 17:15:02 +0000 (20:15 +0300)]
test: add some config file tests

Test the --config=FILE option, and add a broken test for writing
config file through a symbolic link.

11 years agoRevert "emacs: functions to import sender or recipient into BBDB"
David Bremner [Sat, 6 Apr 2013 19:10:28 +0000 (16:10 -0300)]
Revert "emacs: functions to import sender or recipient into BBDB"

This reverts commit 238bf4cb09423cac4efa968e70184daad39e2846.

This commit was causing a build failure.

Bad me for not checking before pushing.

11 years agoemacs: functions to import sender or recipient into BBDB
Daniel Bergey [Sun, 31 Mar 2013 18:20:15 +0000 (14:20 -0400)]
emacs: functions to import sender or recipient into BBDB

From a show buffer, notmuch-bbdb/snarf-from imports the sender into
bbdb.  notmuch-bbdb/snarf-to imports all recipients.  Newly imported
contacts are reported in the minibuffer / Messages buffer.

Both functions use the BBDB parser to recognize email address formats.

11 years agonmbug-status: only import notmuch when needed
Jani Nikula [Mon, 1 Apr 2013 09:44:02 +0000 (12:44 +0300)]
nmbug-status: only import notmuch when needed

Make it possible to use the script to query search views without
notmuch python bindings installed.

11 years agonmbug-status: add support for querying the search views
Jani Nikula [Mon, 1 Apr 2013 09:44:01 +0000 (12:44 +0300)]
nmbug-status: add support for querying the search views

Make it easy for scripts to read the views and corresponding searches.

11 years agocli: conform to same conditional build style as elsewhere in notmuch-show
Jani Nikula [Sat, 30 Mar 2013 13:53:17 +0000 (15:53 +0200)]
cli: conform to same conditional build style as elsewhere in notmuch-show

Conform to the same style for #ifdef GMIME_ATLEAST_26 conditional
builds as elsewhere.

There are no functional changes.

11 years agocli: mime node: abstract decryption and signature verification
Jani Nikula [Sat, 30 Mar 2013 13:53:16 +0000 (15:53 +0200)]
cli: mime node: abstract decryption and signature verification

The code filled with #ifdef GMIME_ATLEAST_26 is difficult to
read. Abstract the decryption and signature verification into
functions, with separate implementations for GMime 2.4 and 2.6, to
clarify the code.

There should be no functional changes.

11 years agocli: crypto: abstract gpg context creation for clarity
Jani Nikula [Sat, 30 Mar 2013 13:53:15 +0000 (15:53 +0200)]
cli: crypto: abstract gpg context creation for clarity

The code filled with #ifdef GMIME_ATLEAST_26 is difficult to
read. Abstract gpg context creation into a function, with separate
implementations for GMime 2.4 and 2.6, to clarify the code.

There should be no functional changes.

11 years agoemacs: hello: use batch count
Mark Walters [Sun, 31 Mar 2013 09:46:03 +0000 (12:46 +0300)]
emacs: hello: use batch count

This modifies notmuch hello to use the new count --batch
functionality. It should give exactly the same results as before but
under many conditions it should be much faster. In particular it is
much faster for remote use.

The code is a little ugly as it has to do some working out of the
query when asking the query and some when dealing with the result.
However, the code path is exactly the same in both local and remote
use.

11 years agotest: notmuch count --batch and --input options
Jani Nikula [Sun, 31 Mar 2013 09:46:02 +0000 (12:46 +0300)]
test: notmuch count --batch and --input options

11 years agoman: document notmuch count --batch and --input options
Jani Nikula [Sun, 31 Mar 2013 09:46:01 +0000 (12:46 +0300)]
man: document notmuch count --batch and --input options

11 years agocli: add --batch option to notmuch count
Jani Nikula [Sun, 31 Mar 2013 09:46:00 +0000 (12:46 +0300)]
cli: add --batch option to notmuch count

Add support for reading queries from stdin, one per line, and writing
results to stdout, one per line.

This will bring considerable performance improvements when utilized in
Emacs notmuch-hello, especially so when running remote notmuch.

11 years agocli: extract count printing to a separate function in notmuch count
Jani Nikula [Sun, 31 Mar 2013 09:45:59 +0000 (12:45 +0300)]
cli: extract count printing to a separate function in notmuch count

Make count printing on a query string reusable. No functional changes.

11 years agocli: remove useless talloc_strdup
Jani Nikula [Sun, 31 Mar 2013 09:45:58 +0000 (12:45 +0300)]
cli: remove useless talloc_strdup

If the condition holds, query_string_from_args() has already returned
a talloc allocated empty string. There's no need to duplicate that.

11 years agoemacs: introduce notmuch-command-to-string, replace use of shell-command-to-string
David Bremner [Fri, 8 Mar 2013 13:04:38 +0000 (09:04 -0400)]
emacs: introduce notmuch-command-to-string, replace use of shell-command-to-string

This has two benefits: unified error handling, and avoiding tramp's
hooking into shell-command-string.

This seems to be a fix for id:874nguxbvq.fsf@tu-dortmund.de

11 years agotest: notmuch tag --remove-all
Jani Nikula [Sat, 9 Mar 2013 14:56:51 +0000 (16:56 +0200)]
test: notmuch tag --remove-all

11 years agoman: document notmuch tag --remove-all
Jani Nikula [Sat, 9 Mar 2013 14:56:50 +0000 (16:56 +0200)]
man: document notmuch tag --remove-all

11 years agocli: add --remove-all option to "notmuch tag"
Jani Nikula [Sat, 9 Mar 2013 14:56:49 +0000 (16:56 +0200)]
cli: add --remove-all option to "notmuch tag"

Add --remove-all option to "notmuch tag" to remove all tags from the
messages matching query before applying the tag changes. This allows
removal of all tags and unconditional setting of the tags of a
message:

$ notmuch tag --remove-all id:foo@example.com
$ notmuch tag --remove-all +foo +bar id:foo@example.com

without having to resort to the complicated (and still quoting
broken):

$ notmuch tag $(notmuch search --output=tags '*' | sed 's/^/-/') \
  id:foo@example.com
$ notmuch tag $(notmuch search --output=tags '*' | sed 's/^/-/') \
  +foo +bar id:foo@example.com

11 years agocli: make caller check tag count in parse_tag_command_line
Jani Nikula [Sat, 9 Mar 2013 14:56:48 +0000 (16:56 +0200)]
cli: make caller check tag count in parse_tag_command_line

11 years agocompletion: update README about bash completion dependencies
Jani Nikula [Fri, 29 Mar 2013 20:38:11 +0000 (22:38 +0200)]
completion: update README about bash completion dependencies

11 years agoNEWS: bash completion
Jani Nikula [Fri, 29 Mar 2013 20:38:10 +0000 (22:38 +0200)]
NEWS: bash completion

11 years agocli: config: remove unnecessary braces from if blocks
Jani Nikula [Sat, 30 Mar 2013 14:21:20 +0000 (16:21 +0200)]
cli: config: remove unnecessary braces from if blocks

Cosmetic change to drop unnecessary braces that don't even conform to
the prevailing coding style.

11 years agolib: Fix name reordering to handle commas without spaces
Adam Wolfe Gordon [Mon, 25 Feb 2013 22:47:13 +0000 (15:47 -0700)]
lib: Fix name reordering to handle commas without spaces

Notmuch automatically re-orders names of the format "Last, First" to
"First Last" when the associated email address is
First.Last@example.com. But, if a name is of the format "Last,First"
then notmuch will format the name as "irst Last". Handle any number of
spaces after the comma, including none.

11 years agodevel: add post-release tools news2wiki.pl and man-to-mdwn.pl
Tomi Ollila [Fri, 8 Mar 2013 16:32:23 +0000 (18:32 +0200)]
devel: add post-release tools news2wiki.pl and man-to-mdwn.pl

After new notmuch release has been published the NEWS and manual
pages have been updated using these 2 programs.

Adding the tools to notmuch repository eases their use, adds more
transparency to the "process" and gives more people chance to
do the updates is one is unavailable to do it at the time being.

11 years agodevel/STYLE: information how to enable standard pre-commit hook
Tomi Ollila [Sat, 23 Mar 2013 12:07:15 +0000 (14:07 +0200)]
devel/STYLE: information how to enable standard pre-commit hook

It is easier to enable git standard pre-commit hook, when the
operation to do so is presented.

11 years agocompletion: complete bash completion rewrite
Jani Nikula [Sun, 3 Mar 2013 20:59:28 +0000 (22:59 +0200)]
completion: complete bash completion rewrite

Rewrite the bash completion script to actually do something
useful. Supported completions:

* All the notmuch commands, command line arguments, and values for
  keyword arguments.

* Tags after + and - in 'notmuch tag'.

* Config options in 'notmuch config', and some config option values.

* Search prefixes in all commands that use search terms.

* Tags after tag: prefix in search terms.

* User's email addresses after from: and to: in search terms.

This is all based on the bash-completion package [1], and will not
work without it.

[1] http://bash-completion.alioth.debian.org/

11 years agoemacs: possibility to customize the rendering of tags
Damien Cassou [Sat, 23 Mar 2013 11:29:54 +0000 (12:29 +0100)]
emacs: possibility to customize the rendering of tags

This patch extracts the rendering of tags in notmuch-show to
the notmuch-tag file.

This file introduces a `notmuch-tag-formats' variable that associates
each tag to a particular format. This variable can be customized
thanks to the work of Austin Clements. For example,

  '(("unread" (propertize tag 'face '(:foreground "red")))
    ("flagged" (notmuch-tag-format-image tag "star.svg")))

associates a red foreground to the "unread" tag and a star picture to
the "flagged" tag.

Signed-off-by: Damien Cassou <damien.cassou@gmail.com>
11 years agoemacs: Add notmuch-combine-face-text-property-string
Damien Cassou [Sat, 23 Mar 2013 11:29:53 +0000 (12:29 +0100)]
emacs: Add notmuch-combine-face-text-property-string

Signed-off-by: Damien Cassou <damien.cassou@gmail.com>
11 years agoemacs: Combine string faces and combine under existing faces
Austin Clements [Mon, 4 Feb 2013 21:37:02 +0000 (16:37 -0500)]
emacs: Combine string faces and combine under existing faces

This improves notmuch-combine-face-text-property to support both
applying faces to strings and to support combining the given face
under existing faces, rather than over.

11 years agoemacs: Handle all face forms when combining faces
Austin Clements [Mon, 4 Feb 2013 21:37:01 +0000 (16:37 -0500)]
emacs: Handle all face forms when combining faces

Previously, notmuch-combine-face-text-property assumed that any
existing face properties of the modified text were already in face
list form.  This was true as long as it was the only function
manipulating faces (since it always produced a list form face), but if
anything else has manipulated the face, it was more likely to be
either a face name or a face plist.  It also didn't correctly handle
face lists as arguments, even though the doc string claimed it did.

This patch fixes notmuch-combine-face-text-property to handle all face
forms correctly by canonicalizing both the argument face and the
existing faces into list form.  This also means we can set the face to
a simpler non-list form if there's no existing face.

11 years agodebian/changelog: stanza for 0.15.2-2
David Bremner [Sat, 23 Mar 2013 00:46:57 +0000 (20:46 -0400)]
debian/changelog: stanza for 0.15.2-2

Debian only changes.

11 years agoBug#703608: [PATCH] debian: tighten notmuch-mutt dependency on notmuch
Jameson Graef Rollins [Thu, 21 Mar 2013 13:51:34 +0000 (06:51 -0700)]
Bug#703608: [PATCH] debian: tighten notmuch-mutt dependency on notmuch

notmuch version 0.4 is required for the --output=files option.

11 years agoBug#703608: [PATCH] debian: tighten notmuch-mutt dependency on notmuch
Jameson Graef Rollins [Thu, 21 Mar 2013 13:51:34 +0000 (06:51 -0700)]
Bug#703608: [PATCH] debian: tighten notmuch-mutt dependency on notmuch

notmuch version 0.4 is required for the --output=files option.

11 years agoman: document the notmuch --config=FILE global option
Jani Nikula [Mon, 4 Mar 2013 19:53:15 +0000 (21:53 +0200)]
man: document the notmuch --config=FILE global option

11 years agocli: add top level --config=FILE option
Jani Nikula [Sun, 3 Mar 2013 21:55:10 +0000 (23:55 +0200)]
cli: add top level --config=FILE option

Let the user specify the config file on the command line.

11 years agocli: move config open/close to main() from subcommands
Jani Nikula [Sun, 3 Mar 2013 21:55:09 +0000 (23:55 +0200)]
cli: move config open/close to main() from subcommands

This allows specifying config file as a top level argument to notmuch,
and generally makes it possible to override config file options in
main(), without having to touch the subcommands.

If the config file does not exist, one will be created for the notmuch
main command and setup and help subcommands. Help is special in this
regard; the config is created just to avoid errors about missing
config, but it will not be saved.

This also makes notmuch config the talloc context for subcommands.

11 years agocli: config: make notmuch_config_open() "is new" parameter input only
Jani Nikula [Sun, 3 Mar 2013 21:55:08 +0000 (23:55 +0200)]
cli: config: make notmuch_config_open() "is new" parameter input only

We now have a notmuch_config_is_new() function to query whether a
config was created or not. Change the notmuch_config_open() is_new
parameter into boolean create_new to determine whether the function
should create a new config if one doesn't exist. This reduces the
complexity of the API.

11 years agocli: config: keep track of whether the config is newly created
Jani Nikula [Sun, 3 Mar 2013 21:55:07 +0000 (23:55 +0200)]
cli: config: keep track of whether the config is newly created

Keep track of whether the config is newly created, and add
notmuch_config_is_new() accessor function to query this.

This is to support anyone with a config handle to check this, instead
of just whoever called notmuch_config_open().

11 years agocli: plug main notmuch command into subcommand machinery
Jani Nikula [Sun, 3 Mar 2013 21:55:06 +0000 (23:55 +0200)]
cli: plug main notmuch command into subcommand machinery

This allows top level arguments to be added to notmuch in a way that
doesn't require special handling for the plain notmuch command without
a subcommand.

11 years agocli: abstract subcommand finding into a new function
Jani Nikula [Sun, 3 Mar 2013 21:55:05 +0000 (23:55 +0200)]
cli: abstract subcommand finding into a new function

Clean up code.

11 years agotest/README: mention the test_expect_equal_json and *sanitize* functions
Aaron Ecay [Wed, 6 Mar 2013 03:34:42 +0000 (22:34 -0500)]
test/README: mention the test_expect_equal_json and *sanitize* functions

also fix one typo