]> git.cworth.org Git - obsolete/notmuch-old/commitdiff
emacs: Introduce `notmuch-call-notmuch-sexp'
authorAustin Clements <amdragon@MIT.EDU>
Sun, 23 Jun 2013 23:43:17 +0000 (19:43 -0400)
committerDavid Bremner <bremner@debian.org>
Tue, 25 Jun 2013 05:57:02 +0000 (22:57 -0700)
This is just like `notmuch-call-notmuch-json', but parses S-expression
output.  Note that, also like `notmuch-call-notmuch-json', this
doesn't consider trailing data to be an error, which may or may not be
what we want in the long run.

emacs/notmuch-lib.el

index 79a1290d4a69019b9c159c08ccf8b76f7ef22a38..c82c6c2a63246ede7878fce974d4aa7206c11399 100644 (file)
@@ -489,6 +489,23 @@ an error."
              (json-read)))
        (delete-file err-file)))))
 
+(defun notmuch-call-notmuch-sexp (&rest args)
+  "Invoke `notmuch-command' with ARGS and return the parsed S-exp output.
+
+If notmuch exits with a non-zero status, this will pop up a
+buffer containing notmuch's output and signal an error."
+
+  (with-temp-buffer
+    (let ((err-file (make-temp-file "nmerr")))
+      (unwind-protect
+         (let ((status (apply #'call-process
+                              notmuch-command nil (list t err-file) nil args)))
+           (notmuch-check-exit-status status (cons notmuch-command args)
+                                      (buffer-string) err-file)
+           (goto-char (point-min))
+           (read (current-buffer)))
+       (delete-file err-file)))))
+
 (defun notmuch-start-notmuch (name buffer sentinel &rest args)
   "Start and return an asynchronous notmuch command.