From: Keith Amidon Date: Fri, 27 Nov 2009 13:30:10 +0000 (-0800) Subject: Factor out message buffer mgmt from notmuch-show-view-all-mime-parts X-Git-Tag: 0.1~303 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=c4463d4cb482abebdffe725a85fff35a0eba31a1;p=notmuch.git Factor out message buffer mgmt from notmuch-show-view-all-mime-parts The ability to temporarily create a buffer containing only the contents of the currently selected message in notmuch show mode is generally useful. This commit factors the majority of the code required to do so out of notmuch-show-view-all-mime-parts into a macro called with-current-notmuch-show-message and rewrites the original function in terms of the macro. A future set of commits will provide additional functionality using the macro as well. --- diff --git a/notmuch.el b/notmuch.el index 7eca87ae..da5a98c7 100644 --- a/notmuch.el +++ b/notmuch.el @@ -283,17 +283,21 @@ buffer." (interactive) (view-file (notmuch-show-get-filename))) +(defmacro with-current-notmuch-show-message (&rest body) + "Evaluate body with current buffer set to the text of current message" + `(save-excursion + (let ((filename (notmuch-show-get-filename))) + (let ((buf (generate-new-buffer (concat "*notmuch-msg-" filename "*")))) + (with-current-buffer buf + (insert-file-contents filename nil nil nil t) + ,@body) + (kill-buffer buf))))) + (defun notmuch-show-view-all-mime-parts () "Use external viewers (according to mailcap) to view all MIME-encoded parts." (interactive) - (save-excursion - (let ((filename (notmuch-show-get-filename))) - (switch-to-buffer (generate-new-buffer (concat "*notmuch-mime-" - filename - "*"))) - (insert-file-contents filename nil nil nil t) - (mm-display-parts (mm-dissect-buffer)) - (kill-this-buffer)))) + (with-current-notmuch-show-message + (mm-display-parts (mm-dissect-buffer)))) (defun notmuch-reply (query-string) (switch-to-buffer (generate-new-buffer "notmuch-draft"))