comparison lisp/gnus/nnvirtual.el @ 30:ec9a17fef872 r19-15b98

Import from CVS: tag r19-15b98
author cvs
date Mon, 13 Aug 2007 08:52:29 +0200
parents d95e72db5c07
children e04119814345
comparison
equal deleted inserted replaced
29:7976500f47f9 30:ec9a17fef872
98 (save-excursion 98 (save-excursion
99 (set-buffer nntp-server-buffer) 99 (set-buffer nntp-server-buffer)
100 (erase-buffer) 100 (erase-buffer)
101 (if (stringp (car articles)) 101 (if (stringp (car articles))
102 'headers 102 'headers
103 (let ((vbuf (nnheader-set-temp-buffer 103 (let ((vbuf (nnheader-set-temp-buffer
104 (get-buffer-create " *virtual headers*"))) 104 (get-buffer-create " *virtual headers*")))
105 (carticles (nnvirtual-partition-sequence articles)) 105 (carticles (nnvirtual-partition-sequence articles))
106 (system-name (system-name)) 106 (system-name (system-name))
107 cgroup carticle article result prefix) 107 cgroup carticle article result prefix)
108 (while carticles 108 (while carticles
141 ;; the entire buffer, then those articles have been 141 ;; the entire buffer, then those articles have been
142 ;; expired or canceled, so we appropriately update the 142 ;; expired or canceled, so we appropriately update the
143 ;; component group below. They should be coming up 143 ;; component group below. They should be coming up
144 ;; generally in order, so this shouldn't be slow. 144 ;; generally in order, so this shouldn't be slow.
145 (setq articles (delq carticle articles)) 145 (setq articles (delq carticle articles))
146 146
147 (setq article (nnvirtual-reverse-map-article cgroup carticle)) 147 (setq article (nnvirtual-reverse-map-article cgroup carticle))
148 (if (null article) 148 (if (null article)
149 ;; This line has no reverse mapping, that means it 149 ;; This line has no reverse mapping, that means it
150 ;; was an extra article reference returned by nntp. 150 ;; was an extra article reference returned by nntp.
151 (progn 151 (progn
156 (princ article nntp-server-buffer) 156 (princ article nntp-server-buffer)
157 (nnvirtual-update-xref-header cgroup carticle 157 (nnvirtual-update-xref-header cgroup carticle
158 prefix system-name) 158 prefix system-name)
159 (forward-line 1)) 159 (forward-line 1))
160 ) 160 )
161 161
162 (set-buffer vbuf) 162 (set-buffer vbuf)
163 (goto-char (point-max)) 163 (goto-char (point-max))
164 (insert-buffer-substring nntp-server-buffer)) 164 (insert-buffer-substring nntp-server-buffer))
165 ;; Anything left in articles is expired or canceled. 165 ;; Anything left in articles is expired or canceled.
166 ;; Could be smart and not tell it about articles already known? 166 ;; Could be smart and not tell it about articles already known?
194 ((not nnvirtual-last-accessed-component-group) 194 ((not nnvirtual-last-accessed-component-group)
195 (nnheader-report 195 (nnheader-report
196 'nnvirtual "Don't know what server to request from")) 196 'nnvirtual "Don't know what server to request from"))
197 (t 197 (t
198 (save-excursion 198 (save-excursion
199 (when buffer 199 (when buffer
200 (set-buffer buffer)) 200 (set-buffer buffer))
201 (let ((method (gnus-find-method-for-group 201 (let ((method (gnus-find-method-for-group
202 nnvirtual-last-accessed-component-group))) 202 nnvirtual-last-accessed-component-group)))
203 (funcall (gnus-get-function method 'request-article) 203 (funcall (gnus-get-function method 'request-article)
204 article nil (nth 1 method) buffer))))) 204 article nil (nth 1 method) buffer)))))
213 'nnvirtual "Can't open server where %s exists" cgroup)) 213 'nnvirtual "Can't open server where %s exists" cgroup))
214 ((not (gnus-request-group cgroup t)) 214 ((not (gnus-request-group cgroup t))
215 (nnheader-report 'nnvirtual "Can't open component group %s" cgroup)) 215 (nnheader-report 'nnvirtual "Can't open component group %s" cgroup))
216 (t 216 (t
217 (setq nnvirtual-last-accessed-component-group cgroup) 217 (setq nnvirtual-last-accessed-component-group cgroup)
218 (if buffer 218 (if buffer
219 (save-excursion 219 (save-excursion
220 (set-buffer buffer) 220 (set-buffer buffer)
221 (gnus-request-article-this-buffer (cdr amap) cgroup)) 221 (gnus-request-article-this-buffer (cdr amap) cgroup))
222 (gnus-request-article (cdr amap) cgroup)))))))) 222 (gnus-request-article (cdr amap) cgroup))))))))
223 223
260 (t 260 (t
261 (when (or (not dont-check) 261 (when (or (not dont-check)
262 nnvirtual-always-rescan) 262 nnvirtual-always-rescan)
263 (nnvirtual-create-mapping)) 263 (nnvirtual-create-mapping))
264 (setq nnvirtual-current-group group) 264 (setq nnvirtual-current-group group)
265 (nnheader-insert "211 %d 1 %d %s\n" 265 (nnheader-insert "211 %d 1 %d %s\n"
266 nnvirtual-mapping-len nnvirtual-mapping-len group)))) 266 nnvirtual-mapping-len nnvirtual-mapping-len group))))
267 267
268 268
269 (deffoo nnvirtual-request-type (group &optional article) 269 (deffoo nnvirtual-request-type (group &optional article)
270 (if (not article) 270 (if (not article)
282 (= mark nmark) 282 (= mark nmark)
283 (gnus-group-auto-expirable-p cgroup)) 283 (gnus-group-auto-expirable-p cgroup))
284 (setq mark gnus-expirable-mark))) 284 (setq mark gnus-expirable-mark)))
285 mark) 285 mark)
286 286
287 287
288 (deffoo nnvirtual-close-group (group &optional server) 288 (deffoo nnvirtual-close-group (group &optional server)
289 (when (and (nnvirtual-possibly-change-server server) 289 (when (and (nnvirtual-possibly-change-server server)
290 (not (gnus-ephemeral-group-p (nnvirtual-current-group)))) 290 (not (gnus-ephemeral-group-p (nnvirtual-current-group))))
291 (nnvirtual-update-read-and-marked t t)) 291 (nnvirtual-update-read-and-marked t t))
292 t) 292 t)
293 293
294 294
295 (deffoo nnvirtual-request-list (&optional server) 295 (deffoo nnvirtual-request-list (&optional server)
296 (nnheader-report 'nnvirtual "LIST is not implemented.")) 296 (nnheader-report 'nnvirtual "LIST is not implemented."))
297 297
298 298
315 (setcar (nthcdr 3 info) nnvirtual-mapping-marks) 315 (setcar (nthcdr 3 info) nnvirtual-mapping-marks)
316 (when nnvirtual-mapping-marks 316 (when nnvirtual-mapping-marks
317 (setcdr (nthcdr 2 info) (list nnvirtual-mapping-marks)))) 317 (setcdr (nthcdr 2 info) (list nnvirtual-mapping-marks))))
318 (setq nnvirtual-info-installed t)) 318 (setq nnvirtual-info-installed t))
319 t)) 319 t))
320 320
321 321
322 (deffoo nnvirtual-catchup-group (group &optional server all) 322 (deffoo nnvirtual-catchup-group (group &optional server all)
323 (when (and (nnvirtual-possibly-change-server server) 323 (when (and (nnvirtual-possibly-change-server server)
324 (not (gnus-ephemeral-group-p (nnvirtual-current-group)))) 324 (not (gnus-ephemeral-group-p (nnvirtual-current-group))))
325 ;; copy over existing marks first, in case they set anything 325 ;; copy over existing marks first, in case they set anything
407 "Copy marks from the virtual group to the component groups. 407 "Copy marks from the virtual group to the component groups.
408 If READ-P is not nil, update the (un)read status of the components. 408 If READ-P is not nil, update the (un)read status of the components.
409 If UPDATE-P is not nil, call gnus-group-update-group on the components." 409 If UPDATE-P is not nil, call gnus-group-update-group on the components."
410 (when nnvirtual-current-group 410 (when nnvirtual-current-group
411 (let ((unreads (and read-p 411 (let ((unreads (and read-p
412 (nnvirtual-partition-sequence 412 (nnvirtual-partition-sequence
413 (gnus-list-of-unread-articles 413 (gnus-list-of-unread-articles
414 (nnvirtual-current-group))))) 414 (nnvirtual-current-group)))))
415 (type-marks (mapcar (lambda (ml) 415 (type-marks (mapcar (lambda (ml)
416 (cons (car ml) 416 (cons (car ml)
417 (nnvirtual-partition-sequence (cdr ml)))) 417 (nnvirtual-partition-sequence (cdr ml))))
418 (gnus-info-marks (gnus-get-info 418 (gnus-info-marks (gnus-get-info
432 (setq groups nnvirtual-component-groups) 432 (setq groups nnvirtual-component-groups)
433 (while groups 433 (while groups
434 (when (and (setq info (gnus-get-info (pop groups))) 434 (when (and (setq info (gnus-get-info (pop groups)))
435 (gnus-info-marks info)) 435 (gnus-info-marks info))
436 (gnus-info-set-marks info nil))) 436 (gnus-info-set-marks info nil)))
437 437
438 ;; Ok, currently type-marks is an assq list with keys of a mark type, 438 ;; Ok, currently type-marks is an assq list with keys of a mark type,
439 ;; with data of an assq list with keys of component group names 439 ;; with data of an assq list with keys of component group names
440 ;; and the articles which correspond to that key/group pair. 440 ;; and the articles which correspond to that key/group pair.
441 (while (setq mark (pop type-marks)) 441 (while (setq mark (pop type-marks))
442 (setq type (car mark)) 442 (setq type (car mark))
443 (setq groups (cdr mark)) 443 (setq groups (cdr mark))
444 (while (setq carticles (pop groups)) 444 (while (setq carticles (pop groups))
445 (gnus-add-marked-articles (car carticles) type (cdr carticles) 445 (gnus-add-marked-articles (car carticles) type (cdr carticles)
446 nil t)))) 446 nil t))))
447 447
448 ;; possibly update the display, it is really slow 448 ;; possibly update the display, it is really slow
449 (when update-p 449 (when update-p
450 (setq groups nnvirtual-component-groups) 450 (setq groups nnvirtual-component-groups)
451 (while groups 451 (while groups
452 (gnus-group-update-group (pop groups) t)))))) 452 (gnus-group-update-group (pop groups) t))))))
630 carticles) 630 carticles)
631 carticles)) 631 carticles))
632 632
633 633
634 (defun nnvirtual-create-mapping () 634 (defun nnvirtual-create-mapping ()
635 "Build the tables necessary to map between component (group, article) to virtual article. 635 "Build the tables necessary to map between component (group, article) to virtual article.
636 Generate the set of read messages and marks for the virtual group 636 Generate the set of read messages and marks for the virtual group
637 based on the marks on the component groups." 637 based on the marks on the component groups."
638 (let ((cnt 0) 638 (let ((cnt 0)
639 (tot 0) 639 (tot 0)
640 (M 0) 640 (M 0)
676 (setq nnvirtual-mapping-len tot) 676 (setq nnvirtual-mapping-len tot)
677 677
678 678
679 ;; We want the actives list sorted by size, to build the tables. 679 ;; We want the actives list sorted by size, to build the tables.
680 (setq actives (sort actives (lambda (g1 g2) (< (nth 1 g1) (nth 1 g2))))) 680 (setq actives (sort actives (lambda (g1 g2) (< (nth 1 g1) (nth 1 g2)))))
681 681
682 ;; Build the offset table. Largest sized groups are at the front. 682 ;; Build the offset table. Largest sized groups are at the front.
683 (setq nnvirtual-mapping-offsets 683 (setq nnvirtual-mapping-offsets
684 (vconcat 684 (vconcat
685 (nreverse 685 (nreverse
686 (mapcar (lambda (entry) 686 (mapcar (lambda (entry)
687 (cons (nth 0 entry) 687 (cons (nth 0 entry)
688 (- (nth 2 entry) M))) 688 (- (nth 2 entry) M)))
689 actives)))) 689 actives))))
690 690
691 ;; Build the mapping table. 691 ;; Build the mapping table.
692 (setq nnvirtual-mapping-table nil) 692 (setq nnvirtual-mapping-table nil)
693 (setq actives (mapcar (lambda (entry) (nth 1 entry)) actives)) 693 (setq actives (mapcar (lambda (entry) (nth 1 entry)) actives))
694 (while actives 694 (while actives
695 (setq size (car actives)) 695 (setq size (car actives))