database: add n_d_index_file (deprecates n_d_add_message)
authorDaniel Kahn Gillmor <dkg@fifthhorseman.net>
Thu, 17 Aug 2017 23:14:25 +0000 (19:14 -0400)
committerDavid Bremner <david@tethera.net>
Wed, 23 Aug 2017 10:38:37 +0000 (07:38 -0300)
commitb10ce6bc23002d48916b1b2f375480e7540e3164
tree2c403d73fd6373bb943d08aa8a2303afb73dff16
parent09fa51303c6ba5adfd2431d87663523aa799288b
database: add n_d_index_file (deprecates n_d_add_message)

We need a way to pass parameters to the indexing functionality on the
first index, not just on reindexing.  The obvious place is in
notmuch_database_add_message.  But since modifying the argument list
would break both API and ABI, we needed a new name.

I considered notmuch_database_add_message_with_params(), but the
functionality we're talking about doesn't always add a message.  It
tries to index a specific file, possibly adding a message, but
possibly doing other things, like adding terms to an existing message,
or failing to deal with message objects entirely (e.g. because the
file didn't contain a message).

So i chose the function name notmuch_database_index_file.

I confess i'm a little concerned about confusing future notmuch
developers with the new name, since we already have a private
_notmuch_message_index_file function, and the two do rather different
things.  But i think the added clarity for people linking against the
future libnotmuch and the capacity for using index parameters makes
this a worthwhile tradeoff.  (that said, if anyone has another name
that they strongly prefer, i'd be happy to go with it)

This changeset also adjusts the tests so that we test whether the new,
preferred function returns bad values (since the deprecated function
just calls the new one).

We can keep the deprecated n_d_add_message function around as long as
we like, but at the next place where we're forced to break API or ABI
we can probably choose to drop the name relatively safely.

NOTE: there is probably more cleanup to do in the ruby and go bindings
to complete the deprecation directly.  I don't know those languages
well enough to attempt a fix; i don't know how to test them; and i
don't know the culture around those languages about API additions or
deprecations.
12 files changed:
bindings/python/docs/source/database.rst
bindings/python/notmuch/database.py
bindings/python/notmuch/directory.py
bindings/python/notmuch/message.py
bindings/ruby/database.c
contrib/go/src/notmuch/notmuch.go
lib/add-message.cc
lib/notmuch.h
notmuch-insert.c
notmuch-new.c
test/T070-insert.sh
test/T560-lib-error.sh