Return-Path: X-Original-To: notmuch@notmuchmail.org Delivered-To: notmuch@notmuchmail.org Received: from localhost (localhost [127.0.0.1]) by olra.theworths.org (Postfix) with ESMTP id 4483D431FB6 for ; Tue, 21 Aug 2012 00:35:08 -0700 (PDT) X-Virus-Scanned: Debian amavisd-new at olra.theworths.org X-Spam-Flag: NO X-Spam-Score: 0 X-Spam-Level: X-Spam-Status: No, score=0 tagged_above=-999 required=5 tests=[none] autolearn=disabled Received: from olra.theworths.org ([127.0.0.1]) by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id wQu4IE9wGVsi for ; Tue, 21 Aug 2012 00:35:07 -0700 (PDT) Received: from guru.guru-group.fi (guru.guru-group.fi [46.183.73.34]) by olra.theworths.org (Postfix) with ESMTP id 0C613431FAE for ; Tue, 21 Aug 2012 00:35:07 -0700 (PDT) Received: by guru.guru-group.fi (Postfix, from userid 501) id 9CE1C100386; Tue, 21 Aug 2012 10:35:14 +0300 (EEST) From: Tomi Ollila To: Ben Gamari , notmuch@notmuchmail.org Subject: Re: [PATCH 1/3] Add notmuch_database_close_compact In-Reply-To: <1345476704-17091-2-git-send-email-bgamari.foss@gmail.com> References: <1345476704-17091-1-git-send-email-bgamari.foss@gmail.com> <1345476704-17091-2-git-send-email-bgamari.foss@gmail.com> User-Agent: Notmuch/0.13.2+128~g2eb637a (http://notmuchmail.org) Emacs/23.1.1 (x86_64-redhat-linux-gnu) X-Face: HhBM'cA~ MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-BeenThere: notmuch@notmuchmail.org X-Mailman-Version: 2.1.13 Precedence: list List-Id: "Use and development of the notmuch mail system." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 21 Aug 2012 07:35:08 -0000 On Mon, Aug 20 2012, Ben Gamari wrote: > --- > configure | 25 ++++++++++++++++++++++++- > lib/database.cc | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ > lib/notmuch.h | 14 ++++++++++++++ > 3 files changed, 92 insertions(+), 1 deletion(-) > > diff --git a/configure b/configure > index dc0dba4..370fedd 100755 > --- a/configure > +++ b/configure > @@ -270,7 +270,8 @@ printf "Checking for Xapian development files... " > have_xapian=0 > for xapian_config in ${XAPIAN_CONFIG}; do > if ${xapian_config} --version > /dev/null 2>&1; then > - printf "Yes (%s).\n" $(${xapian_config} --version | sed -e 's/.* //') > + xapian_version=$(${xapian_config} --version | sed -e 's/.* //') > + printf "Yes (%s).\n" ${xapian_version} > have_xapian=1 > xapian_cxxflags=$(${xapian_config} --cxxflags) > xapian_ldflags=$(${xapian_config} --libs) > @@ -282,6 +283,24 @@ if [ ${have_xapian} = "0" ]; then > errors=$((errors + 1)) > fi > > +have_xapian_compact=0 > +if [ ${have_xapian} = "1" ]; then > + printf "Checking for Xapian compact support... " > + IFS='.' > + old_args=$@ > + set -- ${xapian_version} > + xapian_major_version=$1 > + xapian_minor_version=$2 > + xapian_subminor_version=$3 > + set -- ${old_args} The part above breaks the argument vector in case there are spaces in args (I though $IFS chars, but try the script), execute: $ echo '#!/bin/bash IFS=. for x in "$@"; do echo $x; done; echo foo=$@ for x in $foo; do echo $x; done; echo set -- $foo for x in "$@"; do echo $x; done; echo ' > foo.bash $ bash foo.bash a "b c" d Also, after processing, IFS is not restored (to $DEFAULT_IFS) an alternative is to put the code in function like the following way: set_xapian_version () { xapian_major_version=$1 xapian_minor_version=$2 xapian_subminor_version=$3 } have_xapian_compact=0 if [ ${have_xapian} = "1" ]; then printf "Checking for Xapian compact support... " IFS=. set_xapian_version ${xapian_version} IFS=$DEFAULT_IFS if [ "${xapian_major_version}" -gt 1 ] || [ ${xapian_minor_version} -gt 2 ] || [ ${xapian_subminor_version} -ge 6 ]; then printf "Yes.\n" have_xapian_compact=1 else printf "No.\n" fi fi Hmm, I guess the check above is to determine whether xapian version is 1.2.6 or newer, but is there xapian version 1.1.6 or 1.0.6 or 0.3.0 or so ? I am not qualified to comment about compaction itself :) In the last patch you give copyright to Carl (which is OK). However I'd debate whether it is good practise to declare Carl as author; I'd say that is OK if he agrees to claim authorship to your potentially shi^H^H^Hperfect code ;) There are at least a few style issues below: e.g. no space between function name and opening parenthesis. Tomi > + if [ "${xapian_major_version}" -gt 1 ] || [ ${xapian_minor_version} -gt 2 ] || [ ${xapian_subminor_version} -ge 6 ]; then > + printf "Yes.\n" > + have_xapian_compact=1 > + else > + printf "No.\n" > + fi > +fi > + > printf "Checking for GMime development files... " > have_gmime=0 > IFS=';' > @@ -675,6 +694,9 @@ LINKER_RESOLVES_LIBRARY_DEPENDENCIES = ${linker_resolves_library_dependencies} > XAPIAN_CXXFLAGS = ${xapian_cxxflags} > XAPIAN_LDFLAGS = ${xapian_ldflags} > > +# Whether compact is supported by this version of Xapian > +HAVE_XAPIAN_COMPACT = ${have_xapian_compact} > + > # Flags needed to compile and link against GMime-2.4 > GMIME_CFLAGS = ${gmime_cflags} > GMIME_LDFLAGS = ${gmime_ldflags} > @@ -711,6 +733,7 @@ CONFIGURE_CFLAGS = -DHAVE_GETLINE=\$(HAVE_GETLINE) \$(GMIME_CFLAGS) \\ > CONFIGURE_CXXFLAGS = -DHAVE_GETLINE=\$(HAVE_GETLINE) \$(GMIME_CFLAGS) \\ > \$(TALLOC_CFLAGS) -DHAVE_VALGRIND=\$(HAVE_VALGRIND) \\ > \$(VALGRIND_CFLAGS) \$(XAPIAN_CXXFLAGS) \\ > + -DHAVE_XAPIAN_COMPACT=\$(HAVE_XAPIAN_COMPACT) \\ > -DHAVE_STRCASESTR=\$(HAVE_STRCASESTR) > CONFIGURE_LDFLAGS = \$(GMIME_LDFLAGS) \$(TALLOC_LDFLAGS) \$(XAPIAN_LDFLAGS) > EOF > diff --git a/lib/database.cc b/lib/database.cc > index 761dc1a..6e83a61 100644 > --- a/lib/database.cc > +++ b/lib/database.cc > @@ -781,6 +781,60 @@ notmuch_database_close (notmuch_database_t *notmuch) > } > > void > +notmuch_database_close_compact (notmuch_database_t *notmuch) > +{ > + void *local = talloc_new (NULL); > + Xapian::Compactor compactor; > + char *notmuch_path, *xapian_path, *compact_xapian_path, *old_xapian_path; > + > +#if HAVE_XAPIAN_COMPACT > + if (! (notmuch_path = talloc_asprintf (local, "%s/%s", notmuch->path, ".notmuch"))) { > + fprintf (stderr, "Out of memory\n"); > + goto DONE; > + } > + > + if (! (xapian_path = talloc_asprintf (local, "%s/%s", notmuch_path, "xapian"))) { > + fprintf (stderr, "Out of memory\n"); > + goto DONE; > + } > + > + if (! (compact_xapian_path = talloc_asprintf (local, "%s.compact", xapian_path))) { > + fprintf (stderr, "Out of memory\n"); > + goto DONE; > + } > + > + if (! (old_xapian_path = talloc_asprintf (local, "%s.old", xapian_path))) { > + fprintf (stderr, "Out of memory\n"); > + goto DONE; > + } > + > + try { > + compactor.set_renumber(false); > + compactor.add_source(xapian_path); > + compactor.set_destdir(compact_xapian_path); > + compactor.compact(); > + > + if (rename(xapian_path, old_xapian_path)) { > + fprintf (stderr, "Error moving old database out of the way\n"); > + goto DONE; > + } > + > + if (rename(compact_xapian_path, xapian_path)) { > + fprintf (stderr, "Error moving compacted database\n"); > + goto DONE; > + } > + } catch (Xapian::InvalidArgumentError e) { > + fprintf (stderr, "Error while compacting: %s", e.get_msg().c_str()); > + } > + > +#endif > + > + notmuch_database_close(notmuch); > +DONE: > + talloc_free(local); > +} > + > +void > notmuch_database_destroy (notmuch_database_t *notmuch) > { > notmuch_database_close (notmuch); > diff --git a/lib/notmuch.h b/lib/notmuch.h > index 3633bed..50babfb 100644 > --- a/lib/notmuch.h > +++ b/lib/notmuch.h > @@ -215,6 +215,20 @@ notmuch_database_open (const char *path, > void > notmuch_database_close (notmuch_database_t *database); > > +/* Close the given notmuch database and then compact it. > + * > + * After notmuch_database_close_compact has been called, calls to > + * other functions on objects derived from this database may either > + * behave as if the database had not been closed (e.g., if the > + * required data has been cached) or may fail with a > + * NOTMUCH_STATUS_XAPIAN_EXCEPTION. > + * > + * notmuch_database_close_compact can be called multiple times. Later > + * calls have no effect. > + */ > +void > +notmuch_database_close_compact (notmuch_database_t *notmuch); > + > /* Destroy the notmuch database, closing it if necessary and freeing > * all associated resources. */ > void > -- > 1.7.9.5 > > _______________________________________________ > notmuch mailing list > notmuch@notmuchmail.org > http://notmuchmail.org/mailman/listinfo/notmuch