summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--email.org289
1 files changed, 169 insertions, 120 deletions
diff --git a/email.org b/email.org
index d01eb13..29b3a0e 100644
--- a/email.org
+++ b/email.org
@@ -344,55 +344,6 @@
nnrss-directory (jao-gnus-dir "rss"))
#+end_src
* notmuch
-*** hello page
- #+begin_src emacs-lisp
- (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<)))))
-
- (defun jao--refresh-agenda () (save-window-excursion (org-agenda-list)))
-
- (defun jao-notmuch-refresh-hello ()
- (interactive)
- (notmuch-refresh-this-buffer)
- (let ((inhibit-message t))
- (beginning-of-buffer)
- (widget-forward 2)))
-
- (with-eval-after-load "notmuch-hello"
- (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 "toread" nil "r" '("tag:toread"))
- ,(jao-notmuch--q "new" nil "n" '("tag:new"))))
- (add-hook 'notmuch-hello-refresh-hook #'jao--refresh-agenda))
-
- (setq notmuch-hello-sections '(notmuch-hello-insert-saved-searches
- notmuch-hello-insert-alltags
- ;; notmuch-hello-insert-recent-searches
- notmuch-hello-insert-header)
- notmuch-hello-thousands-separator ","
- notmuch-hello-recent-searches-max 5
- notmuch-show-all-tags-list t
- notmuch-show-logo nil
- notmuch-show-empty-saved-searches nil)
- #+end_src
*** jumping from/to index
#+begin_src emacs-lisp
(defvar-local jao-notmuch--tree-buffer nil)
@@ -434,37 +385,38 @@
(notmuch-refresh-this-buffer)))))
#+end_src
-*** commands
+*** shared commands
#+begin_src emacs-lisp
- (defun jao-notmuch-jump ()
+ (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")
(let ((resize-mini-windows t)) (notmuch-tag-jump reverse)))
- (defun jao-notmuch-tree-tag (&optional new)
+ (defun jao-notmuch-tree-by-tag (&optional new)
+ "Jump to a tag tree search, using its key, and ensuring minibuffer can grow."
(interactive "P")
(when-let (tag (notmuch-select-tag-with-completion "Forest of tag: "))
(notmuch-tree (concat "tag:" tag) (when new "tag:/unread|new/"))))
- (defun jao-notmuch-tree-delete-next (reverse)
- (interactive "P")
- (notmuch-tree-tag
- (notmuch-tag-change-list '("+deleted" "-unread" "-new") reverse))
+ (defun jao-notmuch-tree--tag-next (tags reverse &optional thread)
+ (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-mail-clean-address (fun address)
- (let ((address (if (string-match ".+ updates on arXiv.org: \\(.+\\)"
- address)
- (with-temp-buffer
- (insert (match-string 1 address))
- (let ((shr-width 1000))
- (shr-render-region (point-min) (point-max)))
- (buffer-string))
- address)))
- (funcall fun address)))
+ (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))
+
+ (defun jao-notmuch-tree-flagged-next (reverse)
+ (interactive "P")
+ (jao-notmuch-tree--tag-next '("+flagged") reverse))
(defun jao-notmuch-follow-link (&optional external)
(interactive "P")
@@ -497,38 +449,107 @@
(jao-emms-echo)))
(error "Found an enclosure, but not a link!")))))
+
#+end_src
-*** package
+*** hello
#+begin_src emacs-lisp
- (use-package notmuch
- :ensure t
- :demand t
+ (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-fcc-dirs
- '(("jao@bigml.com" . "bigml/sent") (".*" . "jao/sent"))
- notmuch-message-headers-visible t
- jao-notmuch-message-headers '("Subject" "To" "Cc" "Date"
- "List-Id" "List-ID" "Reply-To"
- "X-Mailer" "User-Agent" "X-User-Agent")
- notmuch-message-headers jao-notmuch-message-headers
- notmuch-show-mark-read-tags '("-new" "-unread")
- notmuch-archive-tags '("+trove" "-new" "-unread" "-inbox")
- notmuch-tagging-keys
- '(("a" notmuch-archive-tags "Archive")
- ("d" notmuch-show-mark-read-tags "Mark read")
- ("u" ("+new" "+unread") "Mark unred read")
- ("f" ("+flagged") "Flag")
- ("r" ("+toread") "Read later")
- ("x" ("+deleted" "-new" "-flagged" "-unread") "Deleted"))
- notmuch-show-all-multipart/alternative-parts nil
- notmuch-show-indent-messages-width 2
+ (setq notmuch-hello-sections '(notmuch-hello-insert-saved-searches
+ notmuch-hello-insert-alltags
+ ;; notmuch-hello-insert-recent-searches
+ notmuch-hello-insert-header)
+ notmuch-hello-thousands-separator ","
+ notmuch-hello-recent-searches-max 5
+ notmuch-show-all-tags-list t
+ notmuch-show-logo nil
+ notmuch-show-empty-saved-searches nil)
+ (defun jao--refresh-agenda () (save-window-excursion (org-agenda-list)))
+
+ (defun jao-notmuch-refresh-hello ()
+ (interactive)
+ (notmuch-refresh-this-buffer)
+ (let ((inhibit-message t))
+ (beginning-of-buffer)
+ (widget-forward 2)))
+
+ :hook (notmuch-hello-refresh-hook . jao--refresh-agenda)
+ :bind (:map notmuch-hello-mode-map
+ (("g" . jao-notmuch-refresh-hello)
+ ("S" . consut-notmuch)
+ ("k" . nil))))
+
+ #+end_src
+*** show
+ #+begin_src emacs-lisp
+ (use-package notmuch-show
+ :init
+ (setq notmuch-show-all-multipart/alternative-parts nil
+ notmuch-show-indent-messages-width 0
notmuch-show-imenu-indent t
notmuch-show-part-button-default-action 'notmuch-show-view-part
notmuch-show-only-matching-messages t
- notmuch-tree-result-format
+ notmuch-wash-signature-lines-max 0
+ notmuch-wash-wrap-lines-length 80
+ notmuch-wash-citation-lines-prefix 10
+ notmuch-wash-citation-lines-suffix 20)
+
+ :config
+
+ (defun jao-mail-clean-address (fun address)
+ (let ((address (if (string-match ".+ updates on arXiv.org: \\(.+\\)"
+ address)
+ (with-temp-buffer
+ (insert (match-string 1 address))
+ (let ((shr-width 1000))
+ (shr-render-region (point-min) (point-max)))
+ (buffer-string))
+ address)))
+ (funcall fun address)))
+
+ (advice-add 'notmuch-clean-address :around #'jao-mail-clean-address)
+
+ :bind (:map notmuch-show-mode-map
+ (("h" . jao-notmuch-goto-index-buffer)
+ ("i" . jao-notmuch-toggle-images)
+ ("j" . jao-notmuch-saved-search-jump)
+ ("k" . jao-notmuch-tag-jump)
+ ("C-c C-c" . jao-notmuch-goto-message-in-gnus))))
+ #+end_src
+*** tree
+ #+begin_src emacs-lisp
+ (use-package notmuch-tree
+ :init
+ (setq notmuch-tree-result-format
'(("date" . "%12s ")
("authors" . "%-35s")
- ((("subject" . "%.95s")) . " %-95s")
+ ((("tree" . "%s ")("subject" . "%s")) . " %-95s")
("tags" . " (%s)"))
notmuch-search-result-format
'(("date" . "%12s ")
@@ -536,45 +557,72 @@
("authors" . "%-35s")
("subject" . "%-95s")
("tags" . "(%s)"))
- notmuch-unthreaded-result-format notmuch-tree-result-format
- notmuch-wash-signature-lines-max 0
- notmuch-wash-wrap-lines-length 80
- notmuch-wash-citation-lines-prefix 10
- notmuch-wash-citation-lines-suffix 20)
+ notmuch-unthreaded-result-format notmuch-tree-result-format)
+
:config
- (when (eq 'notmuch jao-afio-mail-function)
- (setq mm-text-html-renderer 'shr))
+ (defun jao-notmuch--format-field (fun field &rest args)
+ (let ((rs (apply fun field args)))
+ (if (and (stringp field) (string= field "tree"))
+ (thread-last (replace-regexp-in-string "►" "➤" rs)
+ (replace-regexp-in-string "╰" "├"))
+ ;; (thread-last (replace-regexp-in-string "►" "➤" rs)
+ rs)))
- (advice-add 'notmuch-clean-address :around #'jao-mail-clean-address)
+ (advice-add 'notmuch-tree-format-field :around #'jao-notmuch--format-field)
- :bind (:map
- notmuch-common-keymap (("T" . jao-notmuch-tree-tag)
- ("E" . jao-notmuch-open-enclosure)
- ("B" . jao-notmuch-browse-urls)
- ("M-g" . jao-notmuch-follow-link)
- ("d" . jao-notmuch-tree-delete-next)
- ("k" . jao-notmuch-tag-jump)
- ("j" . jao-notmuch-jump))
- :map notmuch-message-mode-map
- (("C-c C-d" . notmuch-draft-postpone))
- :map notmuch-show-mode-map
- (("h" . jao-notmuch-goto-index-buffer)
- ("i" . jao-notmuch-toggle-images)
- ("j" . jao-notmuch-jump)
- ("k" . jao-notmuch-tag-jump)
- ("C-c C-c" . jao-notmuch-goto-message-in-gnus))
- :map notmuch-hello-mode-map
- (("g" . jao-notmuch-refresh-hello)
- ("S" . consult-notmuch))
- :map notmuch-tree-mode-map
+ :bind (:map notmuch-tree-mode-map
(("." . jao-notmuch-toggle-mime-parts)
("i" . jao-notmuch-toggle-images)
("h" . jao-notmuch-goto-message-buffer)
("k" . jao-notmuch-tag-jump))))
#+end_src
+*** message
+ #+begin_src emacs-lisp
+ (use-package notmuch-message
+ :init (setq notmuch-fcc-dirs '(("jao@bigml.com" . "bigml/sent")
+ (".*" . "jao/sent")))
+ :bind (:map notmuch-message-mode-map
+ (("C-c C-d" . notmuch-draft-postpone))))
+
+ #+end_src
+*** main
+ #+begin_src emacs-lisp
+ (use-package notmuch
+ :ensure t
+ :demand t
+
+ :init
+ (setq notmuch-show-mark-read-tags '("-new" "-unread")
+ notmuch-archive-tags '("+trove" "-new" "-unread" "-flagged")
+ notmuch-tagging-keys
+ '(("a" notmuch-archive-tags "Archive")
+ ("d" notmuch-show-mark-read-tags "Mark read")
+ ("u" ("+new" "+unread") "Mark unred read")
+ ("f" ("+flagged") "Flag")
+ ("x" ("+deleted" "-new" "-flagged" "-unread") "Deleted")))
+
+ :config
+
+ (when (eq 'notmuch jao-afio-mail-function)
+ (setq mm-text-html-renderer 'shr))
+
+ :bind (:map notmuch-common-keymap
+ (("B" . jao-notmuch-browse-urls)
+ ("E" . jao-notmuch-open-enclosure)
+ ("M-g" . jao-notmuch-follow-link)
+ ("T" . notmuch-search-by-tag)
+ ("U" . notmuch-unthreaded)
+ ("d" . jao-notmuch-tree-delete-next)
+ ("j" . jao-notmuch-saved-search-jump)
+ ("k" . jao-notmuch-tag-jump)
+ ("s" . notmuch-tree)
+ ("t" . jao-notmuch-tree-by-tag)
+ ("u" . jao-notmuch-tree-flagged-next)
+ ("z" . notmuch-search))))
+ #+end_src
*** org mode integration
- Stolen and adapted from [[https://gist.github.com/fedxa/fac592424473f1b70ea489cc64e08911][Fedor Bezrukov]].]
+ Stolen and adapted from [[https://gist.github.com/fedxa/fac592424473f1b70ea489cc64e08911][Fedor Bezrukov]].
#+begin_src emacs-lisp
(with-eval-after-load "org"
(with-eval-after-load "notmuch"
@@ -636,9 +684,10 @@
tag_deleted "bigml.(drivel|lists|deploys|bugs)" 3d
tag_deleted "bigml.reports" 1d
+ tag_deleted "bigml.inbox$" 1y
+ tag_deleted "bigml.support$" 7d
tag_deleted "jao.(drivel|lists|books|think)" 3d
tag_deleted "feeds.+" 3d
- tag_deleted "bigml.inbox$" 1y
#+end_src
*** expire shell script
#+begin_src bash :tangle ./bin/notmuch-expire.sh :tangle-mode (identity #o755)