summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--lib/net/nnnm.el78
1 files changed, 46 insertions, 32 deletions
diff --git a/lib/net/nnnm.el b/lib/net/nnnm.el
index b5f4fe0..552e95c 100644
--- a/lib/net/nnnm.el
+++ b/lib/net/nnnm.el
@@ -85,26 +85,42 @@
(defun nnnm--ids-query (ids) (mapconcat #'identity ids " OR "))
-(defun nnnm--init-group-data (full-group query)
- (nnnm--tag (concat query " AND NOT tag:new AND not tag:nnnm") "+new")
- (let* ((ids (nnnm--search query "tag:nnnm"))
- (nids (length ids))
- (info (gnus-get-info full-group))
- (read (when (> nids 0) (list (cons 1 nids))))
- (marks (list (cons 'seen read))))
+(defun nnnm--prefixed (group server)
+ (gnus-group-prefixed-name group `(nnnm ,server)))
+
+(defun nnnm--get-group-marks (group server)
+ (gnus-info-marks (gnus-get-info (nnnm--prefixed group server))))
+
+(defun nnnm--set-group-marks (marks group server)
+ (let* ((full-group (nnnm--prefixed group server))
+ (info (gnus-get-info full-group)))
(gnus-info-set-marks info marks)
- (setf (gnus-info-read info) read)
- (gnus-set-info full-group info)
- (mapcar #'list ids)))
+ (gnus-set-info full-group info)))
+
+(defun nnnm--subtract-from-ranges (ranges lst)
+ (let ((ranges (gnus-uncompress-sequence ranges)))
+ (dolist (n lst)
+ (let ((rs (seq-group-by (lambda (r) (> n r)) ranges)))
+ (setq ranges
+ (append (alist-get t rs) (mapcar #'1- (alist-get nil rs))))))
+ (gnus-compress-sequence ranges)))
+
+(defun nnnm--remove-articles-from-marks (ranges group server)
+ (let ((marks (nnnm--get-group-marks group server))
+ (lst (gnus-uncompress-sequence ranges))
+ (new-marks))
+ (dolist (m marks)
+ (push (cons (car m) (nnnm--subtract-from-ranges (cdr m))) lst))
+ (nnnm--set-group-marks marks group server)))
+
+(defun nnnm--set-active (n group server)
+ (gnus-set-active (nnnm--prefixed group server) (cons 1 n)))
(defun nnnm--update-group-data (group &optional server)
- ;; (when (and server (not (nnnm-server-opened server)))
- ;; (nnnm-open-server server))
(when-let (query (nnnm--find-query group))
- (let* ((full-group (gnus-group-prefixed-name group `(nnnm ,server)))
- (data (or (nnnm--group-data group)
- (nnnm--init-group-data full-group query)))
- (ids (nnnm--search query "tag:new AND NOT tag:nnnm"))
+ (let* ((data (or (nnnm--group-data group)
+ (mapcar #'list (nnnm--search query "NOT tag:new"))))
+ (ids (nnnm--search query "tag:new"))
(nids (length ids))
(new-data (mapcar (lambda (id)
(list id (nnnm--find-message-file id)))
@@ -113,8 +129,7 @@
(nnnm--tag (nnnm--ids-query ids) "-new")
(nnheader-report 'nnnm "%s: %d new messages retrieved" group nids))
(nnnm--set-group-data group (append data new-data))
- (gnus-set-active (gnus-group-prefixed-name group `(nnnm ,server))
- (cons 1 (+ nids (length data))))
+ (nnnm--set-active (+ nids (length data)) group server)
(length ids))))
@@ -129,10 +144,7 @@
(deffoo nnnm-open-server (server &optional defs)
(nnoo-change-server 'nnnm server defs)
(setq nnnm--group-data nil)
- ;; (when (and nnnm-maildir (file-exists-p nnnm-maildir))
- ;; )
- (message "defs: %s" defs)
- (nnheader-report 'nnnm "Opened server %s using maildir %s" server nnnm-maildir)
+ (nnheader-report 'nnnm "Opened server %s" server)
t)
(deffoo nnnm-close-server (_server)
@@ -140,7 +152,6 @@
(deffoo nnnm-request-regenerate (_server)
(setq nnnm--group-data nil)
- (nnnm--tag "*" "-nnnm")
t)
(deffoo nnnm-request-list (&optional _server)
@@ -191,19 +202,23 @@
((not (save-excursion (nnmail-find-file file)))
(nnheader-report 'nnnm "Couldn't read file: %s" file))
(t
- (nnnm--tag id "+nnnm")
+ (nnnm--tag id "-unread")
(nnheader-report 'nnnm "Article %s retrieved and tagged" id)
(cons group id)))))
(deffoo nnnm-request-expire-articles (articles group &optional _server _force)
- (let ((excluded) (ids))
- (dolist (a articles)
- (if-let (id (car (nnnm--article-data a group)))
- (push id ids)
- (push a excluded)))
+ (let* ((articles (gnus-uncompress-range articles))
+ (ids (mapcar (lambda (a) (car (nnnm--article-data a group))) articles)))
(when ids
- (nnnm--tag (nnnm--ids-query ids) "+deleted +nnnm"))
- excluded))
+ (nnnm--tag (nnnm--ids-query ids) "+deleted")
+ (let ((data (nnnm--group-data group)))
+ (dolist (id ids)
+ (setq data
+ (cl-delete-if (lambda (d) (string= (car d) id)) data :count 1)))
+ (nnnm--set-group-data group data)
+ (nnnm--remove-articles-from-marks articles group server)
+ (nnnm--set-active (length data) group server)))
+ articles))
(deffoo nnnm-request-set-mark (group actions &optional _server)
(message "set marks: %s: %S" group actions)
@@ -244,7 +259,6 @@
(deffoo nnnm-close-group (_group &optional _server) t)
-
(provide 'nnnm)