summaryrefslogtreecommitdiff
path: root/lisp/gnus/nnmh.el
diff options
context:
space:
mode:
authorLars Magne Ingebrigtsen <larsi@gnus.org>2010-09-04 00:45:13 +0000
committerKatsumi Yamaoka <yamaoka@jpl.org>2010-09-04 00:45:13 +0000
commiteecdcaf581984698081637f2f8ce0f0a0f701de0 (patch)
tree9faeb11062b27d3ddd5a30918b7c8bb40dbf6c66 /lisp/gnus/nnmh.el
parent8fab3e398d5759069a6f12584fda35d227906364 (diff)
downloademacs-eecdcaf581984698081637f2f8ce0f0a0f701de0.tar.gz
emacs-eecdcaf581984698081637f2f8ce0f0a0f701de0.tar.bz2
emacs-eecdcaf581984698081637f2f8ce0f0a0f701de0.zip
mm-util.el: Just return the image directories, not all directories in the path in addition to the image directories; Maintain a cache of the image directories. This means that the `g' command in Gnus doesn't have to stat dozens of directories each time; nnmh.el: Only recurse down into subdirectories if the link count is more than 2. This results in a 100x speed up on my nnmh spool, and that's from an SSD disk, and not over nfs.
Diffstat (limited to 'lisp/gnus/nnmh.el')
-rw-r--r--lisp/gnus/nnmh.el35
1 files changed, 21 insertions, 14 deletions
diff --git a/lisp/gnus/nnmh.el b/lisp/gnus/nnmh.el
index 05eb669fa0b..86f751c7669 100644
--- a/lisp/gnus/nnmh.el
+++ b/lisp/gnus/nnmh.el
@@ -207,21 +207,29 @@ as unread by Gnus.")
(defun nnmh-request-list-1 (dir)
(setq dir (expand-file-name dir))
;; Recurse down all directories.
- (let ((dirs (and (file-readable-p dir)
- (nnheader-directory-files dir t nil t)))
- rdir)
+ (let ((files (nnheader-directory-files dir t nil t))
+ (max 0)
+ min rdir attributes num)
;; Recurse down directories.
- (while (setq rdir (pop dirs))
- (when (and (file-directory-p rdir)
+ (dolist (rdir files)
+ (setq attributes (file-attributes rdir))
+ (when (null (nth 0 attributes))
+ (setq file (file-name-nondirectory rdir))
+ (when (string-match "^[0-9]+$" file)
+ (setq num (string-to-number file))
+ (setq max (max max num))
+ (when (or (null min)
+ (< num min))
+ (setq min num))))
+ (when (and (eq (nth 0 attributes) t) ; Is a directory
+ (> (nth 1 attributes) 2) ; Has sub-directories
(file-readable-p rdir)
(not (equal (file-truename rdir)
(file-truename dir))))
- (nnmh-request-list-1 rdir))))
- ;; For each directory, generate an active file line.
- (unless (string= (expand-file-name nnmh-toplev) dir)
- (let ((files (mapcar 'string-to-number
- (directory-files dir nil "^[0-9]+$" t))))
- (when files
+ (nnmh-request-list-1 rdir)))
+ ;; For each directory, generate an active file line.
+ (unless (string= (expand-file-name nnmh-toplev) dir)
+ (when min
(with-current-buffer nntp-server-buffer
(goto-char (point-max))
(insert
@@ -233,14 +241,13 @@ as unread by Gnus.")
(file-truename (file-name-as-directory
(expand-file-name nnmh-toplev))))
dir)
- (mm-string-to-multibyte ;Why? Isn't it multibyte already?
+ (mm-string-to-multibyte ;Why? Isn't it multibyte already?
(mm-encode-coding-string
(nnheader-replace-chars-in-string
(substring dir (match-end 0))
?/ ?.)
nnmail-pathname-coding-system)))
- (apply 'max files)
- (apply 'min files)))))))
+ max min))))))
t)
(deffoo nnmh-request-newgroups (date &optional server)