summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--init.org9
-rw-r--r--lib/net/jao-notmuch.el50
2 files changed, 33 insertions, 26 deletions
diff --git a/init.org b/init.org
index ae1c606..68d44b1 100644
--- a/init.org
+++ b/init.org
@@ -2224,10 +2224,11 @@
#+begin_src emacs-lisp
(use-package poly-org :ensure t)
- (use-package org-auto-tangle
- :ensure t
- :hook (org-mode . org-auto-tangle-mode)
- :diminish)
+ ;; (use-package org-auto-tangle
+ ;; :ensure t
+ ;; :hook (org-mode . org-auto-tangle-mode)
+ ;; :diminish)
+
#+end_src
***** Some helper packages
#+begin_SRC emacs-lisp
diff --git a/lib/net/jao-notmuch.el b/lib/net/jao-notmuch.el
index 5916840..fd2694f 100644
--- a/lib/net/jao-notmuch.el
+++ b/lib/net/jao-notmuch.el
@@ -24,6 +24,8 @@
;;; Code:
+(require 'eww)
+
(require 'notmuch)
(require 'notmuch-tree)
(require 'notmuch-show)
@@ -41,7 +43,7 @@
(match-string 0 full-path)
(user-error "Message not in any mailbox!")))
-(defun jao-notmuch-msg-props ()
+(defun jao-notmuch--msg-props ()
(if-let ((p (save-excursion
(text-property-search-forward :notmuch-message-properties))))
(prop-match-value p)
@@ -50,32 +52,30 @@
(defun jao-notmuch--move (full-path &optional d)
(let* ((ff (jao-notmuch--path-to-mailbox full-path))
(d (or d (completing-read (format "From %s to: " ff)
- (remove ff jao-notmuch-mailboxes)
- nil
- t)))
+ (remove ff jao-notmuch-mailboxes) nil t)))
(dest (string-replace ff d full-path))
(dest (replace-regexp-in-string ",U=.+$" "" dest))
(fnd (file-name-nondirectory full-path))
- (dnd (file-name-nondirectory dest))
- (prompt (format "%s/%s -> %s/%s? " ff fnd d dnd)))
- (when (y-or-n-p prompt)
- (let ((c (notmuch-tag-change-list (split-string ff "/") t))
- (cc (notmuch-tag-change-list (split-string d "/"))))
- (notmuch-tree-tag (append c cc)))
+ (dnd (file-name-nondirectory dest)))
+ (when (y-or-n-p (format "%s/%s -> %s/%s? " ff fnd d dnd))
+ (notmuch-tree-tag (append (notmuch-tag-change-list (split-string ff "/") t)
+ (split-string d "/")))
(notmuch-tree-close-message-window)
(rename-file full-path dest)
(shell-command-to-string "notmuch new")
(notmuch-refresh-this-buffer))))
(defun jao-notmuch-move-message ()
+ "Move message at point to another folder."
(interactive)
- (let* ((p (jao-notmuch-msg-props))
+ (let* ((p (jao-notmuch--msg-props))
(f (car (plist-get p :filename))))
(jao-notmuch--move (or f ""))))
(defun jao-notmuch-tree-spam ()
- (interactive)
- (let* ((p (jao-notmuch-msg-props))
+ "Move message at point to the spam folder."
+ (interactive)
+ (let* ((p (jao-notmuch--msg-props))
(f (car (plist-get p :filename)))
(mbox (car (split-string (jao-notmuch--path-to-mailbox f) "/"))))
(notmuch-tree-tag '("-new" "-unread"))
@@ -102,11 +102,11 @@
(unless (eq 'url (jao-notmuch-goto-message-buffer t))
(pop-to-buffer b))))
-(defun jao-notmuch-goto-index-buffer ()
+(defun jao-notmuch-goto-tree-buffer ()
(interactive)
(if (buffer-live-p jao-notmuch--tree-buffer)
(pop-to-buffer jao-notmuch--tree-buffer)
- (user-error "No index for this buffer")))
+ (user-error "No tree view for this buffer")))
(defun jao-notmuch-browse-urls ()
(interactive)
@@ -125,7 +125,7 @@
(when (re-search-forward "\\[ multipart/alternative \\]" nil t)
(while (forward-button 1 nil nil t)
(notmuch-show-toggle-part-invisibility)))))
- (jao-notmuch-goto-index-buffer)))
+ (jao-notmuch-goto-tree-buffer)))
(defun jao-notmuch-toggle-images ()
(interactive)
@@ -144,21 +144,27 @@
(save-excursion
(goto-char (point-min))
(let ((p) (cnt))
- (while (setq p (text-property-search-forward
- :notmuch-message-properties))
+ (while (setq p (text-property-search-forward :notmuch-message-properties))
(unless cnt (setq cnt 0))
(let ((tags (plist-get (prop-match-value p) :tags)))
(when (or (member "unread" tags) (member "new" tags))
(setq cnt (1+ cnt)))))
cnt)))
-(defun jao-notmuch-tree-update-buffer-name (&optional n)
+(defun jao-notmuch--tree-update-buffer-name (&optional n)
(when-let ((n (or n (jao-notmuch--unread-count))))
(rename-buffer (format "*%s - {%s messages left}*"
notmuch-tree-basic-query
n))
(jao-minibuffer-refresh)))
+(defun jao-notmuch-echo-count ()
+ "Show the number of unread messages left in this tree view."
+ (interactive)
+ (when-let ((n (jao-notmuch--unread-count)))
+ (jao-notmuch--tree-update-buffer-name n)
+ (message "%s messages left" n)))
+
(defun jao-notmuch-tree-next (thread &optional no-exit)
"Next message or thread in forest or exit if none."
(interactive "P")
@@ -166,7 +172,7 @@
(progn (notmuch-tree-next-thread)
(notmuch-tree-show-message nil))
(notmuch-tree-next-matching-message (not no-exit)))
- (jao-notmuch-tree-update-buffer-name))
+ (jao-notmuch--tree-update-buffer-name))
;; Tagging
@@ -201,7 +207,7 @@
(notmuch-tree-next-matching-message t)
(when (not (window-live-p notmuch-tree-message-window))
(notmuch-tree-show-message nil)))
- (jao-notmuch-tree-update-buffer-name))
+ (jao-notmuch--tree-update-buffer-name))
(defun jao-notmuch-tree-show-or-scroll ()
"Show current message, or scroll it if visible."
@@ -209,7 +215,7 @@
(if (window-live-p notmuch-tree-message-window)
(scroll-other-window 1)
(notmuch-tree-show-message nil)
- (jao-notmuch-tree-update-buffer-name)))
+ (jao-notmuch--tree-update-buffer-name)))
(provide 'jao-notmuch)