diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/jao-maildir.el | 35 |
1 files changed, 18 insertions, 17 deletions
diff --git a/net/jao-maildir.el b/net/jao-maildir.el index ec6ac28..2177009 100644 --- a/net/jao-maildir.el +++ b/net/jao-maildir.el @@ -65,17 +65,19 @@ (defun jao-maildir--set-trackers (maildirs tracked-maildirs) (jao-maildir--init-counts maildirs) (let* ((label-mboxes (make-hash-table :test 'equal)) - (trackers (mapcar (lambda (track) - (puthash (car track) () label-mboxes) - (let ((tr (seq-take track 2)) - (l (elt track 2))) - (append tr - (cond ((eq l t) '(jao-maildir-emph)) - ((null l) '(default)) - (t (list l)))))) + (trackers (seq-map-indexed + (lambda (track idx) + (puthash (car track) () label-mboxes) + (let ((tr (seq-take track 2)) + (l (elt track 2))) + (append tr + (cond ((eq l t) '(jao-maildir-emph)) + ((null l) '(default)) + (t (list l))) + (list (or (elt track 3) idx))))) tracked-maildirs))) (dolist (mbox maildirs) - (let ((lb (seq-find (lambda (lb) (string-match-p lb mbox)) + (let ((lb (seq-find (lambda (lb) (when lb (string-match-p lb mbox))) (hash-table-keys label-mboxes)))) (puthash lb (cons mbox (gethash lb label-mboxes)) label-mboxes))) (setq jao-maildir--label-mboxes label-mboxes) @@ -93,13 +95,11 @@ (other (assoc-delete-all label jao-maildir--track-strings)) (cnt (jao-maildir--tracked-count track))) (if (> cnt 0) - (let* ((face (last track)) - (str (cons label - (propertize (format "%s%s" label cnt) 'face face)))) - (setq jao-maildir--track-strings - (if (eq face 'default) - (append other (list str)) - (cons str other)))) + (let* ((face (car (last (butlast track)))) + (order (car (last track))) + (str (propertize (format "%s%s" label cnt) 'face face)) + (str (cons label (cons order str)))) + (setq jao-maildir--track-strings (cons str other))) (setq jao-maildir--track-strings other))))) ;;;###autoload @@ -109,7 +109,8 @@ ((stringp mbox) (puthash mbox (jao-maildir--maildir-new-count mbox) jao-maildir--counts) (jao-maildir--update-track-string mbox))) - (let ((s (mapconcat 'identity (mapcar 'cdr jao-maildir--track-strings) " "))) + (let* ((s (seq-sort-by #'cadr #'< jao-maildir--track-strings)) + (s (mapconcat 'identity (mapcar 'cddr s) " "))) (setq jao-maildir-info-string (if (string-blank-p s) "" (concat s " ")))) (when jao-maildir-echo-p (jao-minibuffer-refresh))) |