diff options
author | jao <jao@gnu.org> | 2021-05-07 00:16:32 +0100 |
---|---|---|
committer | jao <jao@gnu.org> | 2021-05-07 00:16:32 +0100 |
commit | e4cdb0f77e523ee4d2405f2f6621039ae93b0ed5 (patch) | |
tree | dec52ef5f4c9ae58b1df7019704599831f30fb8f | |
parent | 0fa8928fe36ec0c4affb5f11739b375983f91c04 (diff) | |
download | elibs-e4cdb0f77e523ee4d2405f2f6621039ae93b0ed5.tar.gz elibs-e4cdb0f77e523ee4d2405f2f6621039ae93b0ed5.tar.bz2 |
notmuch comfort
-rw-r--r-- | email.org | 40 |
1 files changed, 26 insertions, 14 deletions
@@ -262,12 +262,19 @@ #+begin_src emacs-lisp (defvar-local jao-notmuch--tree-buffer nil) - (defun jao-notmuch-goto-message-buffer () - (interactive) + (defun jao-notmuch-goto-message-buffer (&optional and-click) + (interactive "P") (when (window-live-p notmuch-tree-message-window) (let ((b (current-buffer))) (select-window notmuch-tree-message-window) - (setq-local jao-notmuch--tree-buffer b)))) + (setq-local jao-notmuch--tree-buffer b) + (when (and and-click (button-at (point))) + (push-button)) + t))) + + (defun jao-notmuch-goto-message-buffer* () + (interactive) + (save-window-excursion (jao-notmuch-goto-message-buffer t))) (defun jao-notmuch-goto-index-buffer () (interactive) @@ -297,7 +304,8 @@ (defun jao-notmuch-toggle-images () (interactive) (save-window-excursion - (when (jao-notmuch-goto-message-buffer) + (jao-notmuch-goto-message-buffer) + (when (derived-mode-p 'notmuch-show-mode) (let ((notmuch-show-text/html-blocked-images nil) (shr-inhibit-images nil) (shr-blocked-images nil)) @@ -558,22 +566,25 @@ (scroll-other-window 1) (notmuch-tree-show-message nil))) - (defun jao-notmuch-tree-delete-next (reverse) - "Mark as deleted current message and move to next. Prefix undeletes." + (defun jao-notmuch-tree-delete (reverse &optional next) + "Mark as deleted current message. Prefix undeletes." (interactive "P") (notmuch-tree-tag (notmuch-tag-change-list '("+deleted" "-unread" "-new") reverse)) - (notmuch-tree-next-message)) + (when next (notmuch-tree-next-message))) - (defun jao-notmuch-tree-undelete-next (reverse) + (defun jao-notmuch-tree-undelete (reverse) "Mark as not-deleted current message and move to next." (interactive "P") - (jao-notmuch-tree-delete-next (not reverse))) + (jao-notmuch-tree-delete (not reverse))) - (defun jao-notmuch-tree-read-thread-next () + (defun jao-notmuch-tree-read-thread-next (&optional delete) "Mark the current thread as read and move to next one." - (interactive) - (jao-notmuch-tree--tag-next '("-unread" "-new") nil t)) + (interactive "P") + (jao-notmuch-tree--tag-next (if delete + '("+deleted" "-unread" "-new") + '("-unread" "-new")) + nil t)) (dolist (f '(notmuch-tree-match-tree-face notmuch-tree-no-match-tree-face)) @@ -592,9 +603,10 @@ :bind (:map notmuch-tree-mode-map (("." . jao-notmuch-toggle-mime-parts) ("i" . jao-notmuch-toggle-images) - ("d" . jao-notmuch-tree-delete-next) - ("D" . jao-notmuch-tree-undelete-next) + ("d" . jao-notmuch-tree-delete) + ("D" . jao-notmuch-tree-undelete) ("h" . jao-notmuch-goto-message-buffer) + ("H" . jao-notmuch-goto-message-buffer*) ("K" . jao-notmuch-tag-jump) ("k" . jao-notmuch-tree-read-thread-next) ("n" . jao-notmuch-tree-next) |