diff options
author | jao <jao@gnu.org> | 2021-04-26 04:07:02 +0100 |
---|---|---|
committer | jao <jao@gnu.org> | 2021-04-26 04:07:02 +0100 |
commit | 705ad2cb9c452de23b146be8c6bfc445b0a06aa1 (patch) | |
tree | 3aaa376ab260a9ddeb716d3d2b7614c33bad7545 | |
parent | b82671b0620e9d978fc753f2059fcb2708254dda (diff) | |
download | elibs-705ad2cb9c452de23b146be8c6bfc445b0a06aa1.tar.gz elibs-705ad2cb9c452de23b146be8c6bfc445b0a06aa1.tar.bz2 |
better jumpy saved searches in notmuch
-rw-r--r-- | email.org | 87 |
1 files changed, 50 insertions, 37 deletions
@@ -380,11 +380,6 @@ #+end_src *** shared commands #+begin_src emacs-lisp - (defun jao-notmuch-saved-search-jump () - "Jump to a saved search, using its key, and ensuring minibuffer can grow." - (interactive) - (let ((resize-mini-windows t)) (notmuch-jump-search))) - (defun jao-notmuch-tag-jump (reverse) "Create a jump menu for tagging operations, ensuring minibuffer can grow." (interactive "P") @@ -400,12 +395,10 @@ (if thread (notmuch-tree-tag-thread (notmuch-tag-change-list tags reverse)) (notmuch-tree-tag (notmuch-tag-change-list tags reverse))) - (notmuch-tree-next-matching-message)) - - (defun jao-notmuch-tree-delete-next (thread) - "Mark as deleted current message (or thread, with prefix) and move to next." - (interactive "P") - (jao-notmuch-tree--tag-next '("+deleted" "-unread" "-new") nil thread)) + (if thread + (notmuch-tree-next-thread) + (notmuch-tree-next-matching-message)) + (notmuch-tree-show-message nil)) (defun jao-notmuch-tree-flagged-next (reverse) (interactive "P") @@ -444,35 +437,55 @@ #+end_src +*** searches + #+begin_src emacs-lisp + (defun jao-notmuch--and (frags) + (when frags (mapconcat #'identity frags " AND "))) + + (defvar jao-notmuch-alt-searches '()) + + (defun jao-notmuch-saved-search-jump () + "Jump to a saved search, using its key, for the alt list." + (interactive) + (let ((resize-mini-windows t) + (notmuch-saved-searches jao-notmuch-alt-searches)) + (notmuch-jump-search))) + + (defun jao-notmuch--q-base (d0 d1 k q) + (list :name (concat d0 (when d1 "/") d1) + :search-type 'tree :key k :query q)) + + (defun jao-notmuch--q (d0 d1 &optional k qs) + (when (null qs) + (add-to-list 'jao-notmuch-alt-searches + (jao-notmuch--q-base d0 d1 k + (format "folder:%s/%s" d0 d1)) + t)) + (let ((q (or (jao-notmuch--and qs) + (format "folder:%s/%s and tag:unread" d0 d1)))) + (jao-notmuch--q-base d0 d1 nil q))) + + (defun jao-notmuch--mboxes-search (box &rest excluded) + (let ((ms (seq-difference (jao-list-mailboxes box) excluded)) + (bp (substring box 0 1))) + (mapcar `(lambda (m) + (jao-notmuch--q ,box (car m) (concat ,bp (cdr m)))) + (shorten-strings (sort ms #'string<))))) + + (setq notmuch-saved-searches + `(,(jao-notmuch--q "bigml" "inbox" "bi") + ,@(jao-notmuch--mboxes-search "bigml" "inbox" "deploys") + ,(jao-notmuch--q "jao" "inbox" "ji") + ,@(jao-notmuch--mboxes-search "jao" "inbox") + ,@(jao-notmuch--mboxes-search "feeds") + ,(jao-notmuch--q "bml/today" nil "tb" '("tag:bigml" "date:1d..")) + ,(jao-notmuch--q "jao/today" nil "tj" '("tag:jao" "date:1d..")) + ,(jao-notmuch--q "flagged" nil "r" '("tag:flagged")) + ,(jao-notmuch--q "new" nil "n" '("tag:new")))) + #+end_src *** hello #+begin_src emacs-lisp (use-package notmuch-hello - :config - (defun jao-notmuch--and (frags) - (when frags (mapconcat #'identity frags " AND "))) - - (defun jao-notmuch--q (d0 d1 &optional k qs) - (list :name (concat d0 (when d1 "/") d1) :search-type 'tree :key k - :query (or (jao-notmuch--and qs) - (format "folder:%s/%s and tag:unread" d0 d1)))) - - (defun jao-notmuch--mboxes-search (box &rest excluded) - (let ((ms (seq-difference (jao-list-mailboxes box) excluded)) - (bp (substring box 0 1))) - (mapcar `(lambda (m) - (jao-notmuch--q ,box (car m) (concat ,bp (cdr m)))) - (shorten-strings (sort ms #'string<))))) - - (setq notmuch-saved-searches - `(,(jao-notmuch--q "bigml" "inbox" "bi") - ,@(jao-notmuch--mboxes-search "bigml" "inbox" "deploys") - ,(jao-notmuch--q "jao" "inbox" "ji") - ,@(jao-notmuch--mboxes-search "jao" "inbox") - ,@(jao-notmuch--mboxes-search "feeds") - ,(jao-notmuch--q "bml/today" nil "tb" '("tag:bigml" "date:1d..")) - ,(jao-notmuch--q "jao/today" nil "tj" '("tag:jao" "date:1d..")) - ,(jao-notmuch--q "flagged" nil "r" '("tag:flagged")) - ,(jao-notmuch--q "new" nil "n" '("tag:new")))) :init (setq notmuch-hello-sections '(notmuch-hello-insert-saved-searches notmuch-hello-insert-alltags |