From: Jani Nikula Date: Sat, 1 Mar 2014 13:17:50 +0000 (+0200) Subject: emacs: use the originating buffer's working directory for pipe X-Git-Tag: 0.18_rc0~122 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=ec13bd12e3335d0ceb878d403d11004bbe330c8e;p=notmuch.git emacs: use the originating buffer's working directory for pipe Currently notmuch-show-pipe-message runs the command in the working directory of the *notmuch-pipe* buffer if it exists, and the current buffer's working directory (which is inherited to the new *notmuch-pipe* buffer) otherwise. This is all very surprising to the user, and it's difficult to know or change where the command will be run. Always use the current show buffer's working directory for piping. The user can check that with M-x pwd and change it with M-x cd. This is consistent with notmuch-show-pipe-part. --- diff --git a/emacs/notmuch-show.el b/emacs/notmuch-show.el index 88752f17..b8782ddb 100644 --- a/emacs/notmuch-show.el +++ b/emacs/notmuch-show.el @@ -1781,10 +1781,14 @@ message." (setq shell-command (concat notmuch-command " show --format=raw " (shell-quote-argument (notmuch-show-get-message-id)) " | " command))) - (let ((buf (get-buffer-create (concat "*notmuch-pipe*")))) + (let ((cwd default-directory) + (buf (get-buffer-create (concat "*notmuch-pipe*")))) (with-current-buffer buf (setq buffer-read-only nil) (erase-buffer) + ;; Use the originating buffer's working directory instead of + ;; that of the pipe buffer. + (cd cwd) (let ((exit-code (call-process-shell-command shell-command nil buf))) (goto-char (point-max)) (set-buffer-modified-p nil)