[PATCH v2] contrib: notmuch-pick: add tests
authorMark Walters <markwalters1009@gmail.com>
Thu, 1 Nov 2012 19:25:10 +0000 (19:25 +0000)
committerW. Trevor King <wking@tremily.us>
Fri, 7 Nov 2014 17:50:15 +0000 (09:50 -0800)
63/7acf4ade73330daabc81be2e38764874307431 [new file with mode: 0644]

diff --git a/63/7acf4ade73330daabc81be2e38764874307431 b/63/7acf4ade73330daabc81be2e38764874307431
new file mode 100644 (file)
index 0000000..9ce3d60
--- /dev/null
@@ -0,0 +1,435 @@
+Return-Path: <markwalters1009@gmail.com>\r
+X-Original-To: notmuch@notmuchmail.org\r
+Delivered-To: notmuch@notmuchmail.org\r
+Received: from localhost (localhost [127.0.0.1])\r
+       by olra.theworths.org (Postfix) with ESMTP id 13A02431FBC\r
+       for <notmuch@notmuchmail.org>; Thu,  1 Nov 2012 12:25:25 -0700 (PDT)\r
+X-Virus-Scanned: Debian amavisd-new at olra.theworths.org\r
+X-Spam-Flag: NO\r
+X-Spam-Score: 0.201\r
+X-Spam-Level: \r
+X-Spam-Status: No, score=0.201 tagged_above=-999 required=5\r
+       tests=[DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1,\r
+       FREEMAIL_ENVFROM_END_DIGIT=1, FREEMAIL_FROM=0.001,\r
+       RCVD_IN_DNSWL_LOW=-0.7] autolearn=disabled\r
+Received: from olra.theworths.org ([127.0.0.1])\r
+       by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024)\r
+       with ESMTP id 5Tz2EcO95IJc for <notmuch@notmuchmail.org>;\r
+       Thu,  1 Nov 2012 12:25:23 -0700 (PDT)\r
+Received: from mail-we0-f181.google.com (mail-we0-f181.google.com\r
+       [74.125.82.181]) (using TLSv1 with cipher RC4-SHA (128/128 bits))\r
+       (No client certificate requested)\r
+       by olra.theworths.org (Postfix) with ESMTPS id 3BD26431FAE\r
+       for <notmuch@notmuchmail.org>; Thu,  1 Nov 2012 12:25:23 -0700 (PDT)\r
+Received: by mail-we0-f181.google.com with SMTP id u54so1439422wey.26\r
+       for <notmuch@notmuchmail.org>; Thu, 01 Nov 2012 12:25:21 -0700 (PDT)\r
+DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113;\r
+       h=from:to:cc:subject:date:message-id:x-mailer:mime-version\r
+       :content-type:content-transfer-encoding;\r
+       bh=Mg0FVTey8mXm3gcp/PkMxmu7Wm89OWK+sRy32qTMiCg=;\r
+       b=dCr558ujq3Ej1Q9n8kh5PzEsH9U1xt22+HO6UaLjSSd9JVtPsW6ihWTG4cHThcaCdj\r
+       Adle5JI/6zA1og5Ags6xc60Bptpmdp7TAJRnCydJEjIFNrCCqdVhxD9FFZ5wo3eCQkbL\r
+       q2/8Ei4QNB5TroVRYkoSsgp4egUSOUNz4IyNLpdAOJm2Z0ZyPDOujzoUFzoVDNRh/CiN\r
+       WsrVWGa+4r5NMNBNPY62APFiWzyIP06ROjI6x8PQHNh6fGcI22PqTAj3DClOxZGHwexd\r
+       JhRHXC08yjFVFj04EmQSzMA9FgngMi7+s8kg1Pd/W3Lo1WAzNVzy2zG08hL5WYE4FgUv\r
+       JIsg==\r
+Received: by 10.180.99.36 with SMTP id en4mr3331238wib.8.1351797921848;\r
+       Thu, 01 Nov 2012 12:25:21 -0700 (PDT)\r
+Received: from localhost (93-97-24-31.zone5.bethere.co.uk. [93.97.24.31])\r
+       by mx.google.com with ESMTPS id eq2sm246857wib.1.2012.11.01.12.25.19\r
+       (version=TLSv1/SSLv3 cipher=OTHER);\r
+       Thu, 01 Nov 2012 12:25:20 -0700 (PDT)\r
+From: Mark Walters <markwalters1009@gmail.com>\r
+To: notmuch@notmuchmail.org\r
+Subject: [PATCH v2] contrib: notmuch-pick: add tests\r
+Date: Thu,  1 Nov 2012 19:25:10 +0000\r
+Message-Id: <1351797910-19305-1-git-send-email-markwalters1009@gmail.com>\r
+X-Mailer: git-send-email 1.7.9.1\r
+MIME-Version: 1.0\r
+Content-Type: text/plain; charset=UTF-8\r
+Content-Transfer-Encoding: 8bit\r
+X-BeenThere: notmuch@notmuchmail.org\r
+X-Mailman-Version: 2.1.13\r
+Precedence: list\r
+List-Id: "Use and development of the notmuch mail system."\r
+       <notmuch.notmuchmail.org>\r
+List-Unsubscribe: <http://notmuchmail.org/mailman/options/notmuch>,\r
+       <mailto:notmuch-request@notmuchmail.org?subject=unsubscribe>\r
+List-Archive: <http://notmuchmail.org/pipermail/notmuch>\r
+List-Post: <mailto:notmuch@notmuchmail.org>\r
+List-Help: <mailto:notmuch-request@notmuchmail.org?subject=help>\r
+List-Subscribe: <http://notmuchmail.org/mailman/listinfo/notmuch>,\r
+       <mailto:notmuch-request@notmuchmail.org?subject=subscribe>\r
+X-List-Received-Date: Thu, 01 Nov 2012 19:25:25 -0000\r
+\r
+The test should be run using the wrapper run-tests.sh.  This links\r
+the tests into the normal notmuch TEST_DIRECTORY and runs them from\r
+there. After the test is complete then the links are removed.\r
+---\r
+\r
+This is version 2 of the patches to add some tests for notmuch pick. \r
+\r
+The main change is that I have added Tomi's suggested wrapper script\r
+(id:m2ip9srpd6.fsf@guru.guru-group.fi) which is much more robust and\r
+generally better than the one I had.\r
+\r
+The other changes are to split out the tests for the default async\r
+parser from those for the sync parser. My guess is that the sync\r
+parser should be removed but it can be useful for debugging so is\r
+probably worth keeping until pick is closer to being ready for proper\r
+mainline.\r
+\r
+Best wishes\r
+\r
+Mark\r
+\r
+\r
+\r
+\r
+ contrib/notmuch-pick/README                        |    5 ++\r
+ contrib/notmuch-pick/run-tests.sh                  |   46 ++++++++++++\r
+ contrib/notmuch-pick/test/emacs-pick               |   76 ++++++++++++++++++++\r
+ contrib/notmuch-pick/test/emacs-pick-sync          |   64 ++++++++++++++++\r
+ .../pick.expected-output/notmuch-pick-show-window  |   32 ++++++++\r
+ .../notmuch-pick-single-thread                     |    6 ++\r
+ .../pick.expected-output/notmuch-pick-tag-inbox    |   53 ++++++++++++++\r
+ 7 files changed, 282 insertions(+), 0 deletions(-)\r
+ create mode 100755 contrib/notmuch-pick/run-tests.sh\r
+ create mode 100755 contrib/notmuch-pick/test/emacs-pick\r
+ create mode 100755 contrib/notmuch-pick/test/emacs-pick-sync\r
+ create mode 100644 contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-show-window\r
+ create mode 100644 contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-single-thread\r
+ create mode 100644 contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-tag-inbox\r
+\r
+diff --git a/contrib/notmuch-pick/README b/contrib/notmuch-pick/README\r
+index 8eed974..4200824 100644\r
+--- a/contrib/notmuch-pick/README\r
++++ b/contrib/notmuch-pick/README\r
+@@ -15,6 +15,11 @@ Then after the "(require 'notmuch)" line in your .emacs file add\r
+ the line "(require 'notmuch-pick nil t)". This will load notmuch-pick on\r
+ your next emacs start.\r
\r
++TEST\r
++\r
++Just execute run-tests.sh and it should all work (it does require that\r
++notmuch has already been built).\r
++\r
+ USING PICK\r
\r
+ The main key entries to notmuch pick are\r
+diff --git a/contrib/notmuch-pick/run-tests.sh b/contrib/notmuch-pick/run-tests.sh\r
+new file mode 100755\r
+index 0000000..97cc9e8\r
+--- /dev/null\r
++++ b/contrib/notmuch-pick/run-tests.sh\r
+@@ -0,0 +1,46 @@\r
++#!/usr/bin/env bash\r
++\r
++set -eu\r
++\r
++fail() {\r
++    echo ERROR $1\r
++    exit 1\r
++}\r
++\r
++TESTS="emacs-pick emacs-pick-sync"\r
++TESTFILES="$TESTS pick.expected-output"\r
++\r
++PICK_DIR="`cd \`dirname "$0"\` && pwd`"\r
++PICK_TEST_DIR="$PICK_DIR/test"\r
++\r
++\r
++for f in $TESTFILES\r
++do\r
++    test -f "$PICK_TEST_DIR/$f" || test -d "$PICK_TEST_DIR/$f" || fail "$PICK_TEST_DIR/$f does not exist"\r
++done\r
++\r
++cd "$PICK_DIR/../../test"\r
++\r
++test -x ../notmuch || fail "`cd .. && pwd`/notmuch has not been built"\r
++\r
++for f in $TESTFILES\r
++do\r
++    if test -f "$f"\r
++    then\r
++      fail "$f exists"\r
++    fi\r
++done\r
++\r
++trap "rm -f $TESTFILES" 0\r
++\r
++for f in $TESTFILES\r
++do\r
++    ln -s "$PICK_TEST_DIR/$f" .\r
++done\r
++\r
++#don't exec -- traps would not run.\r
++for f in $TESTS\r
++do\r
++    echo $f\r
++    ./$f\r
++done\r
+diff --git a/contrib/notmuch-pick/test/emacs-pick b/contrib/notmuch-pick/test/emacs-pick\r
+new file mode 100755\r
+index 0000000..9db4b34\r
+--- /dev/null\r
++++ b/contrib/notmuch-pick/test/emacs-pick\r
+@@ -0,0 +1,76 @@\r
++#!/usr/bin/env bash\r
++\r
++test_description="emacs pick interface"\r
++. test-lib.sh\r
++\r
++EXPECTED=$TEST_DIRECTORY/pick.expected-output\r
++\r
++add_email_corpus\r
++test_begin_subtest "Do we have emacs"\r
++test_emacs '(insert "hello\n")\r
++          (test-output)'\r
++cat <<EOF >EXPECTED\r
++hello\r
++EOF\r
++test_expect_equal_file OUTPUT EXPECTED\r
++\r
++test_begin_subtest "Basic notmuch-pick view in emacs"\r
++test_emacs '(add-to-list (quote load-path) "'$PICK_DIR'")\r
++          (require (quote notmuch-pick))\r
++          (notmuch-pick "tag:inbox")\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-tag-inbox\r
++\r
++test_begin_subtest "Navigation of notmuch-hello to search results"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-pick-from-search-current-query)\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-tag-inbox\r
++\r
++test_begin_subtest "Pick of a single thread (from search)"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-pick-from-search-thread)\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-single-thread\r
++\r
++test_begin_subtest "Pick of a single thread (from show)"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-search-show-thread)\r
++          (notmuch-pick-from-show-current-query)\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-single-thread\r
++\r
++test_begin_subtest "Message window of pick"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-pick-from-search-thread)\r
++          (notmuch-test-wait)\r
++          (select-window notmuch-pick-message-window)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-show-window\r
++\r
++test_done\r
+diff --git a/contrib/notmuch-pick/test/emacs-pick-sync b/contrib/notmuch-pick/test/emacs-pick-sync\r
+new file mode 100755\r
+index 0000000..a7da0ff\r
+--- /dev/null\r
++++ b/contrib/notmuch-pick/test/emacs-pick-sync\r
+@@ -0,0 +1,64 @@\r
++#!/usr/bin/env bash\r
++\r
++test_description="emacs pick interface (sync parser)"\r
++. test-lib.sh\r
++\r
++EXPECTED=$TEST_DIRECTORY/pick.expected-output\r
++\r
++add_email_corpus\r
++test_begin_subtest "Do we have emacs"\r
++test_emacs '(insert "hello\n")\r
++          (test-output)'\r
++cat <<EOF >EXPECTED\r
++hello\r
++EOF\r
++test_expect_equal_file OUTPUT EXPECTED\r
++\r
++test_begin_subtest "Basic notmuch-pick view in emacs"\r
++test_emacs '(add-to-list (quote load-path) "'$PICK_DIR'")\r
++          (require (quote notmuch-pick))\r
++          (setq notmuch-pick-asynchronous-parser nil)\r
++          (notmuch-pick "tag:inbox")\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-tag-inbox\r
++\r
++test_begin_subtest "Navigation of notmuch-hello to search results"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-pick-from-search-current-query)\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-tag-inbox\r
++\r
++test_begin_subtest "Pick of a single thread (from search)"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-pick-from-search-thread)\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-single-thread\r
++\r
++test_begin_subtest "Pick of a single thread (from show)"\r
++test_emacs '(notmuch-hello)\r
++          (goto-char (point-min))\r
++          (re-search-forward "inbox")\r
++          (widget-button-press (1- (point)))\r
++          (notmuch-test-wait)\r
++          (notmuch-search-show-thread)\r
++          (notmuch-pick-from-show-current-query)\r
++          (notmuch-test-wait)\r
++          (test-output)\r
++          (delete-other-windows)'\r
++test_expect_equal_file OUTPUT $EXPECTED/notmuch-pick-single-thread\r
++\r
++test_done\r
+diff --git a/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-show-window b/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-show-window\r
+new file mode 100644\r
+index 0000000..de37267\r
+--- /dev/null\r
++++ b/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-show-window\r
+@@ -0,0 +1,32 @@\r
++Mikhail Gusarov <dottedmag@dottedmag.net> (2009-11-17) (inbox)\r
++Subject: [notmuch] [PATCH 1/2] Close message file after parsing message       headers\r
++To: notmuch@notmuchmail.org\r
++Date: Tue, 17 Nov 2009 21:28:37 +0600\r
++\r
++Keeping unused files open helps to see "Too many open files" often.\r
++\r
++Signed-off-by: Mikhail Gusarov <dottedmag at dottedmag.net>\r
++---\r
++ lib/message-file.c |    5 +++++\r
++ 1 files changed, 5 insertions(+), 0 deletions(-)\r
++\r
++diff --git a/lib/message-file.c b/lib/message-file.c\r
++index 8a3f8ee..197ab01 100644\r
++--- a/lib/message-file.c\r
+++++ b/lib/message-file.c\r
++@@ -325,6 +325,11 @@ notmuch_message_file_get_header (notmuch_message_file_t\r
++*message,\r
++          return decoded_value;\r
++     }\r
++\r
+++    if (message->parsing_finished) {\r
+++        fclose (message->file);\r
+++        message->file = NULL;\r
+++    }\r
+++\r
++     if (message->line)\r
++      free (message->line);\r
++     message->line = NULL;\r
++[ 2-line signature. Click/Enter to show. ]\r
++-- \r
++1.6.3.3\r
+diff --git a/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-single-thread b/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-single-thread\r
+new file mode 100644\r
+index 0000000..c9e5ef8\r
+--- /dev/null\r
++++ b/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-single-thread\r
+@@ -0,0 +1,6 @@\r
++  2009-11-17  Mikhail Gusarov       ┬►[notmuch] [PATCH 1/2] Close message file after parsing message      headers (inbox)\r
++  2009-11-17  Mikhail Gusarov       ├─►[notmuch] [PATCH 2/2] Include <stdint.h> to get uint32_t in C++  file with gcc 4.4 (inbox, unread)\r
++  2009-11-17  Carl Worth            ╰┬►[notmuch] [PATCH 1/2] Close message file after parsing message headers (inbox, unread)\r
++  2009-11-17  Keith Packard          ╰┬► ...                                              (inbox, unread)\r
++  2009-11-18  Carl Worth              ╰─► ...                                             (inbox, unread)\r
++End of search results.\r
+diff --git a/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-tag-inbox b/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-tag-inbox\r
+new file mode 100644\r
+index 0000000..484141e\r
+--- /dev/null\r
++++ b/contrib/notmuch-pick/test/pick.expected-output/notmuch-pick-tag-inbox\r
+@@ -0,0 +1,53 @@\r
++  2010-12-29  François Boulogne     ─►[aur-general] Guidelines: cp, mkdir vs install      (inbox, unread)\r
++  2010-12-16  Olivier Berger        ─►Essai accentué                                      (inbox, unread)\r
++  2009-11-18  Chris Wilson          ─►[notmuch] [PATCH 1/2] Makefile: evaluate pkg-config once (inbox, unread)\r
++  2009-11-18  Alex Botero-Lowry     ┬►[notmuch] [PATCH] Error out if no query is supplied to search       instead of going into an infinite loop (attachment, inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─►[notmuch] [PATCH] Error out if no query is supplied to search instead of going into an infinite loop (inbox, unread)\r
++  2009-11-17  Ingmar Vanhassel      ┬►[notmuch] [PATCH] Typsos                            (inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++  2009-11-17  Adrian Perez de Cast  ┬►[notmuch] Introducing myself                        (inbox, signed, unread)\r
++  2009-11-18  Keith Packard         ├─► ...                                               (inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++  2009-11-17  Israel Herraiz        ┬►[notmuch] New to the list                           (inbox, unread)\r
++  2009-11-18  Keith Packard         ├─► ...                                               (inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++  2009-11-17  Jan Janak             ┬►[notmuch] What a great idea!                        (inbox, unread)\r
++  2009-11-17  Jan Janak             ├─► ...                                               (inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++  2009-11-17  Jan Janak             ┬►[notmuch] [PATCH] Older versions of install do not support -C. (inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++  2009-11-17  Aron Griffis          ┬►[notmuch] archive                                   (inbox, unread)\r
++  2009-11-18  Keith Packard         ╰┬► ...                                               (inbox, unread)\r
++  2009-11-18  Carl Worth             ╰─► ...                                              (inbox, unread)\r
++  2009-11-17  Keith Packard         ┬►[notmuch] [PATCH] Make notmuch-show 'X' (and 'x') commands remove   inbox (and unread) tags (inbox, unread)\r
++  2009-11-18  Carl Worth            ╰─►[notmuch] [PATCH] Make notmuch-show 'X' (and 'x') commands remove inbox (and unread) tags (inbox, unread)\r
++  2009-11-17  Lars Kellogg-Stedman  ┬►[notmuch] Working with Maildir storage?             (inbox, signed, unread)\r
++  2009-11-17  Mikhail Gusarov       ├┬► ...                                               (inbox, signed, unread)\r
++  2009-11-17  Lars Kellogg-Stedman  │╰┬► ...                                              (inbox, signed, unread)\r
++  2009-11-17  Mikhail Gusarov       │ ├─► ...                                             (inbox, unread)\r
++  2009-11-17  Keith Packard         │ ╰┬► ...                                             (inbox, unread)\r
++  2009-11-18  Lars Kellogg-Stedman  │  ╰─► ...                                            (inbox, signed, unread)\r
++  2009-11-18  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++  2009-11-17  Mikhail Gusarov       ┬►[notmuch] [PATCH 1/2] Close message file after parsing message      headers (inbox, unread)\r
++  2009-11-17  Mikhail Gusarov       ├─►[notmuch] [PATCH 2/2] Include <stdint.h> to get uint32_t in C++  file with gcc 4.4 (inbox, unread)\r
++  2009-11-17  Carl Worth            ╰┬►[notmuch] [PATCH 1/2] Close message file after parsing message headers (inbox, unread)\r
++  2009-11-17  Keith Packard          ╰┬► ...                                              (inbox, unread)\r
++  2009-11-18  Carl Worth              ╰─► ...                                             (inbox, unread)\r
++  2009-11-18  Keith Packard         ┬►[notmuch] [PATCH] Create a default notmuch-show-hook that   highlights URLs and uses word-wrap (inbox, unread)\r
++  2009-11-18  Alexander Botero-Low  ╰─►[notmuch] [PATCH] Create a default notmuch-show-hook that highlights URLs and uses word-wrap (inbox, unread)\r
++  2009-11-18  Alexander Botero-Low  ─►[notmuch] request for pull                          (inbox, unread)\r
++  2009-11-18  Jjgod Jiang           ┬►[notmuch] Mac OS X/Darwin compatibility issues      (inbox, unread)\r
++  2009-11-18  Alexander Botero-Low  ╰┬► ...                                               (inbox, unread)\r
++  2009-11-18  Jjgod Jiang            ╰┬► ...                                              (inbox, unread)\r
++  2009-11-18  Alexander Botero-Low    ╰─► ...                                             (inbox, unread)\r
++  2009-11-18  Rolland Santimano     ─►[notmuch] Link to mailing list archives ?           (inbox, unread)\r
++  2009-11-18  Jan Janak             ─►[notmuch] [PATCH] notmuch new: Support for conversion of spool      subdirectories into tags (inbox, unread)\r
++  2009-11-18  Stewart Smith         ─►[notmuch] [PATCH] count_files: sort directory in inode order before statting (inbox, unread)\r
++  2009-11-18  Stewart Smith         ─►[notmuch] [PATCH 2/2] Read mail directory in inode number order (inbox, unread)\r
++  2009-11-18  Stewart Smith         ─►[notmuch] [PATCH] Fix linking with gcc to use g++ to link in C++    libs. (inbox, unread)\r
++  2009-11-18  Lars Kellogg-Stedman  ┬►[notmuch] "notmuch help" outputs to stderr?         (attachment, inbox, signed, unread)\r
++  2009-11-18  Lars Kellogg-Stedman  ╰─► ...                                               (attachment, inbox, signed, unread)\r
++  2009-11-17  Mikhail Gusarov       ─►[notmuch] [PATCH] Handle rename of message file     (inbox, unread)\r
++  2009-11-17  Alex Botero-Lowry     ┬►[notmuch] preliminary FreeBSD support               (attachment, inbox, unread)\r
++  2009-11-17  Carl Worth            ╰─► ...                                               (inbox, unread)\r
++End of search results.\r
+-- \r
+1.7.9.1\r
+\r