emacs: Let the user choose where to compose new mails

Introduce a new defcustom notmuch-mua-compose-in that allows users to
specify where new mails are composed, either in the current window or
in a new window or frame.

Signed-off-by: Jameson Rollins <jrollins@finestructure.net>
This commit is contained in:
Thomas Jost 2012-05-04 12:37:56 +02:00 committed by David Bremner
parent f6c170fabc
commit 832fd1a7a6

View file

@ -37,6 +37,26 @@
:group 'notmuch-send :group 'notmuch-send
:group 'notmuch-hooks) :group 'notmuch-hooks)
(defcustom notmuch-mua-compose-in 'current-window
(concat
"Where to create the mail buffer used to compose a new message.
Possible values are `current-window' (default), `new-window' and
`new-frame'. If set to `current-window', the mail buffer will be
displayed in the current window, so the old buffer will be
restored when the mail buffer is killed. If set to `new-window'
or `new-frame', the mail buffer will be displayed in a new
window/frame that will be destroyed when the buffer is killed.
You may want to customize `message-kill-buffer-on-exit'
accordingly."
(when (< emacs-major-version 24)
" Due to a known bug in Emacs 23, you should not set
this to `new-window' if `message-kill-buffer-on-exit' is
disabled: this would result in an incorrect behavior."))
:group 'notmuch-send
:type '(choice (const :tag "Compose in the current window" current-window)
(const :tag "Compose mail in a new window" new-window)
(const :tag "Compose mail in a new frame" new-frame)))
(defcustom notmuch-mua-user-agent-function 'notmuch-mua-user-agent-full (defcustom notmuch-mua-user-agent-function 'notmuch-mua-user-agent-full
"Function used to generate a `User-Agent:' string. If this is "Function used to generate a `User-Agent:' string. If this is
`nil' then no `User-Agent:' will be generated." `nil' then no `User-Agent:' will be generated."
@ -56,6 +76,23 @@ list."
;; ;;
(defun notmuch-mua-get-switch-function ()
"Get a switch function according to `notmuch-mua-compose-in'."
(cond ((eq notmuch-mua-compose-in 'current-window)
'switch-to-buffer)
((eq notmuch-mua-compose-in 'new-window)
'switch-to-buffer-other-window)
((eq notmuch-mua-compose-in 'new-frame)
'switch-to-buffer-other-frame)
(t (error "Invalid value for `notmuch-mua-compose-in'"))))
(defun notmuch-mua-maybe-set-window-dedicated ()
"Set the selected window as dedicated according to
`notmuch-mua-compose-in'."
(when (or (eq notmuch-mua-compose-in 'new-frame)
(eq notmuch-mua-compose-in 'new-window))
(set-window-dedicated-p (selected-window) t)))
(defun notmuch-mua-user-agent-full () (defun notmuch-mua-user-agent-full ()
"Generate a `User-Agent:' string suitable for notmuch." "Generate a `User-Agent:' string suitable for notmuch."
(concat (notmuch-mua-user-agent-notmuch) (concat (notmuch-mua-user-agent-notmuch)
@ -157,7 +194,8 @@ list."
collect pair))) collect pair)))
(notmuch-mua-mail (plist-get reply-headers :To) (notmuch-mua-mail (plist-get reply-headers :To)
(plist-get reply-headers :Subject) (plist-get reply-headers :Subject)
(notmuch-headers-plist-to-alist reply-headers)))) (notmuch-headers-plist-to-alist reply-headers)
nil (notmuch-mua-get-switch-function))))
;; Insert the message body - but put it in front of the signature ;; Insert the message body - but put it in front of the signature
;; if one is present ;; if one is present
@ -191,6 +229,7 @@ list."
(set-buffer-modified-p nil)) (set-buffer-modified-p nil))
(defun notmuch-mua-forward-message () (defun notmuch-mua-forward-message ()
(funcall (notmuch-mua-get-switch-function) (current-buffer))
(message-forward) (message-forward)
(when notmuch-mua-user-agent-function (when notmuch-mua-user-agent-function
@ -200,6 +239,7 @@ list."
(message-sort-headers) (message-sort-headers)
(message-hide-headers) (message-hide-headers)
(set-buffer-modified-p nil) (set-buffer-modified-p nil)
(notmuch-mua-maybe-set-window-dedicated)
(message-goto-to)) (message-goto-to))
@ -222,6 +262,7 @@ OTHER-ARGS are passed through to `message-mail'."
(message-sort-headers) (message-sort-headers)
(message-hide-headers) (message-hide-headers)
(set-buffer-modified-p nil) (set-buffer-modified-p nil)
(notmuch-mua-maybe-set-window-dedicated)
(message-goto-to)) (message-goto-to))
@ -278,7 +319,7 @@ the From: address first."
(let ((other-headers (let ((other-headers
(when (or prompt-for-sender notmuch-always-prompt-for-sender) (when (or prompt-for-sender notmuch-always-prompt-for-sender)
(list (cons 'From (notmuch-mua-prompt-for-sender)))))) (list (cons 'From (notmuch-mua-prompt-for-sender))))))
(notmuch-mua-mail nil nil other-headers))) (notmuch-mua-mail nil nil other-headers nil (notmuch-mua-get-switch-function))))
(defun notmuch-mua-new-forward-message (&optional prompt-for-sender) (defun notmuch-mua-new-forward-message (&optional prompt-for-sender)
"Invoke the notmuch message forwarding window. "Invoke the notmuch message forwarding window.