emacs: Don't report CLI signals sent by Emacs as errors
authorAustin Clements <amdragon@MIT.EDU>
Sun, 9 Jun 2013 04:45:37 +0000 (00:45 -0400)
committerDavid Bremner <bremner@debian.org>
Wed, 12 Jun 2013 14:53:15 +0000 (23:53 +0900)
Previously, when the user killed the search buffer before the CLI
search process had completed, we would report the signal sent by Emacs
to kill the CLI to the user as an error.  Fix this by only reporting
error exits if the process buffer is still live.  We still report
stderr output regardless in case stderr output was relevant to why the
user killed the search buffer (such as a wrapper script being stuck).

emacs/notmuch-lib.el

index 28f78e0f4337d0623ccb77e3f18f224f9037dead..534f217753cd1f4f474a822f5b3ae801d0ca6489 100644 (file)
@@ -528,8 +528,12 @@ status."
          (when sub-sentinel
            (funcall sub-sentinel proc event))
          ;; Check the exit status.  This will signal an error if the
-         ;; exit status is non-zero.
-         (notmuch-check-async-exit-status proc event real-command err-file)
+         ;; exit status is non-zero.  Don't do this if the process
+         ;; buffer is dead since that means Emacs killed the process
+         ;; and there's no point in telling the user that (but we
+         ;; still check for and report stderr output below).
+         (when (buffer-live-p (process-buffer proc))
+           (notmuch-check-async-exit-status proc event real-command err-file))
          ;; If that didn't signal an error, then any error output was
          ;; really warning output.  Show warnings, if any.
          (let ((warnings