Re: [PATCH 1/3] emacs: Introduce `notmuch-call-notmuch-sexp'
authorAustin Clements <amdragon@MIT.EDU>
Mon, 24 Jun 2013 19:11:16 +0000 (15:11 +2000)
committerW. Trevor King <wking@tremily.us>
Fri, 7 Nov 2014 17:55:43 +0000 (09:55 -0800)
34/7e773ca9243e9baab6cb8f09f1164ed996bd8e [new file with mode: 0644]

diff --git a/34/7e773ca9243e9baab6cb8f09f1164ed996bd8e b/34/7e773ca9243e9baab6cb8f09f1164ed996bd8e
new file mode 100644 (file)
index 0000000..687d82e
--- /dev/null
@@ -0,0 +1,132 @@
+Return-Path: <amdragon@mit.edu>\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 3701B431FBD\r
+       for <notmuch@notmuchmail.org>; Mon, 24 Jun 2013 12:11:45 -0700 (PDT)\r
+X-Virus-Scanned: Debian amavisd-new at olra.theworths.org\r
+X-Spam-Flag: NO\r
+X-Spam-Score: -0.7\r
+X-Spam-Level: \r
+X-Spam-Status: No, score=-0.7 tagged_above=-999 required=5\r
+       tests=[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 8k452kYCOqN7 for <notmuch@notmuchmail.org>;\r
+       Mon, 24 Jun 2013 12:11:36 -0700 (PDT)\r
+Received: from dmz-mailsec-scanner-3.mit.edu (dmz-mailsec-scanner-3.mit.edu\r
+       [18.9.25.14])\r
+       by olra.theworths.org (Postfix) with ESMTP id 4CD73431FAF\r
+       for <notmuch@notmuchmail.org>; Mon, 24 Jun 2013 12:11:36 -0700 (PDT)\r
+X-AuditID: 1209190e-b7f988e0000009a7-38-51c899e7f14f\r
+Received: from mailhub-auth-3.mit.edu ( [18.9.21.43])\r
+       by dmz-mailsec-scanner-3.mit.edu (Symantec Messaging Gateway) with SMTP\r
+       id 3D.F4.02471.7E998C15; Mon, 24 Jun 2013 15:11:35 -0400 (EDT)\r
+Received: from outgoing.mit.edu (outgoing-auth-1.mit.edu [18.9.28.11])\r
+       by mailhub-auth-3.mit.edu (8.13.8/8.9.2) with ESMTP id r5OJBP7f013758; \r
+       Mon, 24 Jun 2013 15:11:35 -0400\r
+Received: from awakening.csail.mit.edu (awakening.csail.mit.edu [18.26.4.91])\r
+       (authenticated bits=0)\r
+       (User authenticated as amdragon@ATHENA.MIT.EDU)\r
+       by outgoing.mit.edu (8.13.8/8.12.4) with ESMTP id r5OJBIn2020025\r
+       (version=TLSv1/SSLv3 cipher=DHE-RSA-AES128-SHA bits=128 verify=NOT);\r
+       Mon, 24 Jun 2013 15:11:19 -0400\r
+Received: from amthrax by awakening.csail.mit.edu with local (Exim 4.80)\r
+       (envelope-from <amdragon@mit.edu>)\r
+       id 1UrCAX-00049U-40; Mon, 24 Jun 2013 15:11:17 -0400\r
+Date: Mon, 24 Jun 2013 15:11:16 -0400\r
+From: Austin Clements <amdragon@MIT.EDU>\r
+To: Mark Walters <markwalters1009@gmail.com>\r
+Subject: Re: [PATCH 1/3] emacs: Introduce `notmuch-call-notmuch-sexp'\r
+Message-ID: <20130624191115.GB2214@mit.edu>\r
+References: <1372030999-1262-1-git-send-email-amdragon@mit.edu>\r
+       <87zjuftjuc.fsf@qmul.ac.uk>\r
+MIME-Version: 1.0\r
+Content-Type: text/plain; charset=us-ascii\r
+Content-Disposition: inline\r
+In-Reply-To: <87zjuftjuc.fsf@qmul.ac.uk>\r
+User-Agent: Mutt/1.5.21 (2010-09-15)\r
+X-Brightmail-Tracker:\r
+ H4sIAAAAAAAAA+NgFmpkleLIzCtJLcpLzFFi42IR4hTV1n0+80SgweltFhar5/JYXL85k9mB\r
+       yWPnrLvsHs9W3WIOYIrisklJzcksSy3St0vgyrhwYD1LwW7BiumfJBoYj/F2MXJySAiYSJz5\r
+       d5cZwhaTuHBvPRuILSSwj1Fi/hTXLkYuIHsjo8Tl1jnMEM5pJolXZx6wQzhLGCVO7N7NBNLC\r
+       IqAqsW//MXYQm01AQ2Lb/uWMILaIgI7E7UMLwOLMAtIS3343g9ULC7hKdM1cxQpi8wpoS8yd\r
+       fJEJYnWsxM1NV5kh4oISJ2c+YYHo1ZK48e8lUA0H2Jzl/zhAwpxAqw59vwrWKiqgIjHl5Da2\r
+       CYxCs5B0z0LSPQuhewEj8ypG2ZTcKt3cxMyc4tRk3eLkxLy81CJdY73czBK91JTSTYzgkJbk\r
+       28H49aDSIUYBDkYlHt4ZMScChVgTy4orcw8xSnIwKYnyfp8OFOJLyk+pzEgszogvKs1JLT7E\r
+       KMHBrCTCGyoClONNSaysSi3Kh0lJc7AoifOK3toZKCSQnliSmp2aWpBaBJOV4eBQkuBdNQOo\r
+       UbAoNT21Ii0zpwQhzcTBCTKcB2h4D0gNb3FBYm5xZjpE/hSjopQ471eQhABIIqM0D64XlnJe\r
+       MYoDvSLMyw1MQEI8wHQF1/0KaDAT0ODJqcdBBpckIqSkGhgDSlm1er9O35u/Svf9uUddmSGn\r
+       /koZmL7Y9VM/kYOzUPme686u7GUXJuUfnC8VvEZY9+TfKu8PZ2/dqV15ySJ3N4dhPe/ZO+Kv\r
+       vD4tO3/xTUPKAc7eOOsb9dudHa3KUm531uh0Nzw3uzvLIPT7CdUdN/5lGa5Jc3syb87ddK/r\r
+       64/v3OJhe75JiaU4I9FQi7moOBEAgdalhRQDAAA=\r
+Cc: notmuch@notmuchmail.org\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: Mon, 24 Jun 2013 19:11:45 -0000\r
+\r
+Yes, and thanks for reminding me about the require's.  I'll do that in\r
+a follow up.  I was thinking of just moving the streaming JSON parser\r
+to a repo on my GitHub account, since maybe somebody some day will\r
+find a use for it, or at least take inspiration from the API (I looked\r
+into streaming JSON parser APIs before embarking on that one and\r
+they're all terrible!)  Mark, you're the only other person who has\r
+touched that code.  Is this plan good with you?\r
+\r
+Quoth Mark Walters on Jun 24 at  8:00 pm:\r
+> \r
+> This series looks good to me +1. \r
+> \r
+> Is it worth removing all the json (3 files with (require 'json) and the\r
+> async json parser) too?\r
+> \r
+> Best wishes\r
+> \r
+> Mark\r
+> \r
+> On Mon, 24 Jun 2013, Austin Clements <amdragon@MIT.EDU> wrote:\r
+> > This is just like `notmuch-call-notmuch-json', but parses S-expression\r
+> > output.  Note that, also like `notmuch-call-notmuch-json', this\r
+> > doesn't consider trailing data to be an error, which may or may not be\r
+> > what we want in the long run.\r
+> > ---\r
+> >  emacs/notmuch-lib.el |   17 +++++++++++++++++\r
+> >  1 file changed, 17 insertions(+)\r
+> >\r
+> > diff --git a/emacs/notmuch-lib.el b/emacs/notmuch-lib.el\r
+> > index 534f217..36eacc1 100644\r
+> > --- a/emacs/notmuch-lib.el\r
+> > +++ b/emacs/notmuch-lib.el\r
+> > @@ -484,6 +484,23 @@ an error."\r
+> >          (json-read)))\r
+> >    (delete-file err-file)))))\r
+> >  \r
+> > +(defun notmuch-call-notmuch-sexp (&rest args)\r
+> > +  "Invoke `notmuch-command' with ARGS and return the parsed S-exp output.\r
+> > +\r
+> > +If notmuch exits with a non-zero status, this will pop up a\r
+> > +buffer containing notmuch's output and signal an error."\r
+> > +\r
+> > +  (with-temp-buffer\r
+> > +    (let ((err-file (make-temp-file "nmerr")))\r
+> > +      (unwind-protect\r
+> > +    (let ((status (apply #'call-process\r
+> > +                         notmuch-command nil (list t err-file) nil args)))\r
+> > +      (notmuch-check-exit-status status (cons notmuch-command args)\r
+> > +                                 (buffer-string) err-file)\r
+> > +      (goto-char (point-min))\r
+> > +      (read (current-buffer)))\r
+> > +  (delete-file err-file)))))\r
+> > +\r
+> >  (defun notmuch-start-notmuch (name buffer sentinel &rest args)\r
+> >    "Start and return an asynchronous notmuch command.\r