diff options
| -rw-r--r-- | email.org | 160 | ||||
| -rw-r--r-- | eww.org | 2 | 
2 files changed, 107 insertions, 55 deletions
| @@ -194,24 +194,96 @@      ;; (jao-sendmail-gmail)      (jao-sendmail-local)    #+END_SRC -* notmucn -*** notmuch config +* notmuch +*** hello page      #+begin_src emacs-lisp        (defun jao-notmuch--mboxes-search (box)          (mapcar (lambda (m) -                  `(:name ,m -                    :search-type tree -                    :query ,(format "folder:%s/%s and tag:unread" box m))) +                  `(:name ,(format "%s:%s" box m) +                          :search-type tree +                          :query ,(format "folder:%s/%s and tag:unread" box m)))                  (jao-list-mailboxes box))) +      (defun jao--refresh-agenda () (save-window-excursion (org-agenda-list))) + +      (with-eval-after-load "notmuch-hello" +        (add-hook 'notmuch-hello-refresh-hook #'jao--refresh-agenda)) + +      (setq notmuch-saved-searches +            `((:name "jao" :key "j" +                     :query "folder:jao/inbox" +                     :search-type tree +                     :count-query "folder:jao/inbox and tag:unread") +              (:name "bigml" :key "b" +               :count-query "folder:bigml/inbox and tag:unread" +               :search-type tree +               :query "folder:bigml/inbox") +              (:name "today" :key "t" :search-type tree +                     :query "tag:/support|inbox|bugs|bills|hacking/ and date:1d..") +              ,@(jao-notmuch--mboxes-search "bigml") +              ,@(jao-notmuch--mboxes-search "jao") +              ,@(jao-notmuch--mboxes-search "feeds") +              (:name "feeds" :query "tag:new and tag:feeds and not tag:emacs" +               :key "f" :search-type tree) +              (:name "new" :query "tag:new" :key "n" :search-type tree)) +            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 +*** extended commands +    #+begin_src emacs-lisp +      (defvar-local jao-notmuch--tree-buffer nil) + +      (defun jao-notmuch-goto-message-buffer () +        (interactive) +        (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)))) + +      (defun jao-notmuch-goto-index-buffer () +        (interactive) +        (if (buffer-live-p jao-notmuch--tree-buffer) +            (pop-to-buffer jao-notmuch--tree-buffer) +          (user-error "No index for this buffer"))) + +      (defun jao-notmuch-jump () +        (interactive) +        (let ((resize-mini-windows t)) (notmuch-jump-search))) + +      (defun jao-notmuch-tag-jump (reverse) +        (interactive "P") +        (let ((resize-mini-windows t)) (notmuch-tag-jump reverse))) + +      (defun jao-notmuch-tree-tag (&optional new) +        (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-browse-urls () +        (interactive) +        (when (or (derived-mode-p 'notmuch-show-mode) +                  (jao-notmuch-goto-message-buffer)) +          (notmuch-show-browse-urls))) +    #+end_src +*** package +    #+begin_src emacs-lisp        (use-package notmuch          :ensure t          :init -        (setq notmuch-fcc-dirs '(("jao@bigml.com" . "bigml/sent") -                                 (".*" . "jao/sent")) +        (setq notmuch-fcc-dirs +              '(("jao@bigml.com" . "bigml/sent") (".*" . "jao/sent"))                notmuch-message-headers-visible t -              notmuch-message-headers '("Subject" "To" "Cc" "Date" "List-Id" -                                        "X-Mailer" "User-Agent" "X-User-Agent") +              jao-notmuch-message-headers '("Subject" "To" "Cc" "Date" "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 '("+archive" "-new" "-unread")                notmuch-tagging-keys @@ -220,55 +292,27 @@                  ("f" ("+flagged") "Flag")                  ("s" ("+spam" "-new") "Mark as spam")                  ("d" ("+deleted" "-new" "-unread") "Delete")) -              notmuch-saved-searches -              `((:name "jao" :key "j" -                       :query "folder:jao/inbox" -                       :search-type tree -                       :count-query "folder:jao/inbox and tag:unread") -                (:name "bigml" :key "b" -                       :count-query "folder:bigml/inbox and tag:unread" -                       :search-type tree -                       :query "folder:bigml/inbox") -                ,@(jao-notmuch--mboxes-search "jao") -                ,@(jao-notmuch--mboxes-search "bigml") -                ,@(jao-notmuch--mboxes-search "feeds") -                (:name "new" :query "tag:new" :key "u" :search-type tree) -                (:name "sent" :query "tag:sent" :key "t" :search-type tree) -                (:name "drafts" :query "tag:draft" :key "d" :search-type tree) -                (:name "all mail" -                       :query "*" :count-query "tag:new" :key "a" :search-type tree)) -              notmuch-hello-sections '(notmuch-hello-insert-saved-searches -                                       notmuch-hello-insert-alltags -                                       notmuch-hello-insert-header) -              notmuch-hello-thousands-separator ","                notmuch-show-all-multipart/alternative-parts nil -              notmuch-show-all-tags-list t                notmuch-show-indent-messages-width 2                notmuch-show-part-button-default-action 'notmuch-show-view-part -              notmuch-show-logo nil -              notmuch-show-empty-saved-searches nil                notmuch-tree-result-format                '(("date" . "%12s  ")                  ("authors" . "%-35s") -                ((("subject" . "%.95s")) . "   %-95s") +                ((("subject" . "%.95s")) . "  %-95s")                  ("tags" . "  (%s)")) +              notmuch-search-result-format +              '(("date" . "%12s ") +                ("count" . "%-7s ") +                ("authors" . "%-35s") +                ("subject" . "%-95s") +                ("tags" . "(%s)")) +              notmuch-show-only-matching-messages t                notmuch-unthreaded-result-format notmuch-tree-result-format                notmuch-wash-wrap-lines-length 80                notmuch-wash-citation-lines-prefix 10                notmuch-wash-citation-lines-suffix 20)          :config - -        (defun jao--refresh-agenda () (save-window-excursion (org-agenda-list))) -        (add-hook 'notmuch-hello-refresh-hook #'jao--refresh-agenda) - -        (defun jao-notmuch-goto-message-buffer () -          (interactive) -          (when (window-live-p notmuch-tree-message-window) -            (select-window notmuch-tree-message-window))) - -        (defun jao-notmuch-jump () -          (interactive) -          (let ((resize-mini-windows t)) (notmuch-jump-search))) +        (setq mm-text-html-renderer 'shr)          (defun jao-mail-clean-address (fun address)            (let ((address (if (string-match ".+ updates on arXiv.org: \\(.+\\)" @@ -283,15 +327,21 @@          (advice-add 'notmuch-clean-address :around #'jao-mail-clean-address) -        :bind (:map notmuch-show-mode-map -                    ("C-c C-c" . jao-notmuch-goto-message-in-gnus) +        :bind (:map +               notmuch-common-keymap (("T" . jao-notmuch-tree-tag) +                                      ("B" . jao-notmuch-browse-urls)) +               :map notmuch-show-mode-map +               (("h" . jao-notmuch-goto-index-buffer) +                ("k" . jao-notmuch-tag-jump) +                ("C-c C-c" . jao-notmuch-goto-message-in-gnus))                 :map notmuch-hello-mode-map                 (("j" . jao-notmuch-jump)                  ("S" . consult-notmuch))                 :map notmuch-tree-mode-map -               (("h" . jao-notmuch-goto-message-buffer)))) +               (("h" . jao-notmuch-goto-message-buffer) +                ("k" . jao-notmuch-tag-jump))))      #+end_src -*** notmuch tagger +*** tag shell script      #+begin_src bash :tangle ./bin/notmuch-tags.sh :tangle-mode (identity #o755)        notmuch new > $HOME/var/log/notmuch.log 2>&1 @@ -308,7 +358,10 @@          notmuch tag +bigml +$f -- tag:new AND folder:bigml/$f        done; -      notmuch tag +feeds -- tag:new AND folder:/feeds.+/ +      for f in ~/var/mail/feeds/*; do +        f=$(basename $f) +        notmuch tag +feeds +$f -- tag:new AND folder:feeds/$f +      done        tag_deleted "/feeds.+/"        notmuch tag +jao -- tag:new AND folder:/jao.+/ @@ -318,13 +371,12 @@          tag_deleted jao/$f        done -      mkdir -p /tmp/trash/notmuch -      notmuch search --output=files --format=text0 tag:deleted xargs -r0 rm +      notmuch search --output=files --format=text0 tag:deleted | xargs -r0 rm        notmuch new >> $HOME/var/log/notmuch.log 2>&1        notmuch compact >> $HOME/var/log/notmuch.log 2>&1      #+end_src -*** notmuch expirer +*** expire shell script      #+begin_src bash :tangle ./bin/notmuch-expire.sh :tangle-mode (identity #o755)        notmuch search --output=files --format=text0 tag:deleted | xargs -r0 rm        notmuch new > $HOME/var/log/notmuch-expire.log 2>&1 @@ -28,7 +28,7 @@              (mm-html-blocked-images nil)              (fill-column (min (window-width) 110)))          (mm-shr handle))) -    (setq mm-text-html-renderer 'jao-eww-html-renderer) +    ;; (setq mm-text-html-renderer 'jao-eww-html-renderer)    #+end_src  * Buffer names    #+begin_src emacs-lisp | 
