unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
* [PATCH] emacs: show: stop stderr appearing in buffer
@ 2013-11-13  9:03 Mark Walters
  2013-11-13 21:58 ` Tomi Ollila
  2013-11-18 11:35 ` David Bremner
  0 siblings, 2 replies; 15+ messages in thread
From: Mark Walters @ 2013-11-13  9:03 UTC (permalink / raw)
  To: notmuch

In emacs 24.3+ the stdout/stderr from externally displaying an
attachment gets inserted into the show buffer. This is caused by
changes in mm-display-external in mm-decode.el.

Ideally, we would put this output in the notmuch errors buffer but the
handler is called asynchronously so we don't know when the output will
appear. Thus if we put it straight into the errors buffer it could get
interleaved with other errors. Also we can't easily tell when we
have got all the error output so can't wait until the process is complete.

One solution would be to create a new buffer for the stderr of each
attachment viewed. Again, since we can't tell when the process has
finished, we can't close these buffers automatically so this will
leave lots of buffers around.

Thus we add a debug variable notmuch-show-attachment-debug: it this is
non-nil we create a new buffer for each viewer; if this variable is
nil we just use a temp buffer which means all error output is
discarded (this is the same behaviour as with emacs pre 24.3).
---

This is a new version of
id:1378502198-7980-1-git-send-email-markwalters1009@gmail.com I don't
think there was complete consensus on the right thing to do here but
most people wanted at least the option of seeing the stderr/stdout.

This keeps the default behaviour the same as before, but adds a debug
variable to put the stderr/stdout in its own buffer.

Note: I always use emacs 23 so this is not heavily tested.

Best wishes

Mark


 emacs/notmuch-show.el |   12 +++++++++++-
 1 files changed, 11 insertions(+), 1 deletions(-)

diff --git a/emacs/notmuch-show.el b/emacs/notmuch-show.el
index f00273a..f9a3344 100644
--- a/emacs/notmuch-show.el
+++ b/emacs/notmuch-show.el
@@ -159,6 +159,8 @@ indentation."
 (make-variable-buffer-local 'notmuch-show-indent-content)
 (put 'notmuch-show-indent-content 'permanent-local t)
 
+(defvar notmuch-show-attachment-debug nil)
+
 (defcustom notmuch-show-stash-mlarchive-link-alist
   '(("Gmane" . "http://mid.gmane.org/")
     ("MARC" . "http://marc.info/?i=")
@@ -2089,8 +2091,16 @@ caller is responsible for killing this buffer as appropriate."
 This ensures that the temporary buffer created for the mm-handle
 is destroyed when FN returns."
   (let ((handle (notmuch-show-current-part-handle)))
+    ;; emacs 24.3+ puts stdout/stderr into the calling buffer so we
+    ;; call it from a temp-buffer, unless
+    ;; notmuch-show-attachment-debug is non-nil in which case we put
+    ;; it in " *notmuch-part*".
     (unwind-protect
-	(funcall fn handle)
+	(if notmuch-show-attachment-debug
+	    (with-current-buffer (generate-new-buffer " *notmuch-part*")
+	      (funcall fn handle))
+	  (with-temp-buffer
+	    (funcall fn handle)))
       (kill-buffer (mm-handle-buffer handle)))))
 
 (defun notmuch-show-part-button-default (&optional button)
-- 
1.7.9.1

^ permalink raw reply related	[flat|nested] 15+ messages in thread
* [PATCH] emacs: show: stop stderr appearing in buffer
@ 2013-09-06 21:16 Mark Walters
  2013-09-10 14:12 ` David Bremner
  0 siblings, 1 reply; 15+ messages in thread
From: Mark Walters @ 2013-09-06 21:16 UTC (permalink / raw)
  To: notmuch

In emacs 24.3+ the stdout/stderr from externally displaying an
attachment gets inserted into the show buffer. This is caused by
changes in mm-display-external in mm-decode.el.

Ideally, we would put this output in the notmuch errors buffer but the
handler is called asynchronously so we don't know when the output will
appear. Thus if we put it straight into the errors buffer it could get
interleaved with other errors, otoh we can't easily tell when we
have got all the error output so can't wait until the process is complete.

This patch just takes the simplest approach and discards the error
output (which means the behaviour is the same as it was with emacs pre
24.3).
---
As I say above it would be nice to capture the error output but it
does not appear to be simple. This is probably worth applying in the
meantime as we definitely don't want the stderr/stdout appearing in
the show buffer.

The bug is easy to reproduce: make a script which outputs to stderr or
stdout and call it on any part with ". o scriptname" (in fact even
". o ls" will do!)

Best wishes

Mark






 emacs/notmuch-show.el |    9 ++++++---
 1 files changed, 6 insertions(+), 3 deletions(-)

diff --git a/emacs/notmuch-show.el b/emacs/notmuch-show.el
index 904b98e..42438ba 100644
--- a/emacs/notmuch-show.el
+++ b/emacs/notmuch-show.el
@@ -2044,9 +2044,12 @@ caller is responsible for killing this buffer as appropriate."
 This ensures that the temporary buffer created for the mm-handle
 is destroyed when FN returns."
   (let ((handle (notmuch-show-current-part-handle)))
-    (unwind-protect
-	(funcall fn handle)
-      (kill-buffer (mm-handle-buffer handle)))))
+    ;; emacs 24.3+ puts stdout/stderr into the calling buffer so we
+    ;; call it from a temp-buffer.
+    (with-temp-buffer
+      (unwind-protect
+	  (funcall fn handle)
+	(kill-buffer (mm-handle-buffer handle))))))
 
 (defun notmuch-show-part-button-default (&optional button)
   (interactive)
-- 
1.7.9.1

^ permalink raw reply related	[flat|nested] 15+ messages in thread

end of thread, other threads:[~2013-11-18 21:16 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-11-13  9:03 [PATCH] emacs: show: stop stderr appearing in buffer Mark Walters
2013-11-13 21:58 ` Tomi Ollila
2013-11-18 11:35 ` David Bremner
2013-11-18 21:10   ` [PATCH v2] " Mark Walters
  -- strict thread matches above, loose matches on Subject: below --
2013-09-06 21:16 [PATCH] " Mark Walters
2013-09-10 14:12 ` David Bremner
2013-09-12  9:33   ` Mark Walters
2013-09-12 10:56     ` David Bremner
2013-09-12 11:49     ` Tomi Ollila
2013-09-12 12:09       ` Mark Walters
2013-09-12 12:20         ` Tomi Ollila
2013-09-12 15:45           ` Mark Walters
2013-09-13  6:13             ` Tomi Ollila
2013-09-12 14:53     ` Austin Clements
2013-09-12 15:43       ` Mark Walters

Code repositories for project(s) associated with this public inbox

	https://yhetil.org/notmuch.git/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).