This commit was generated by cvs2svn to compensate for changes in r6137,
[elisp/gnus.git-] / lisp / nnmh.el
index d3f164a..8aafd7d 100644 (file)
@@ -1,7 +1,5 @@
 ;;; nnmh.el --- mhspool access for Gnus
-
-;; Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001
-;;     Free Software Foundation, Inc.
+;; Copyright (C) 1995,96,97,98 Free Software Foundation, Inc.
 
 ;; Author: Lars Magne Ingebrigtsen <larsi@gnus.org>
 ;;     Masanobu UMEDA <umerin@flab.flab.fujitsu.junet>
 (nnoo-declare nnmh)
 
 (defvoo nnmh-directory message-directory
-  "Mail spool directory.")
+  "*Mail spool directory.")
 
 (defvoo nnmh-get-new-mail t
-  "If non-nil, nnmh will check the incoming mail file and split the mail.")
+  "*If non-nil, nnmh will check the incoming mail file and split the mail.")
 
 (defvoo nnmh-prepare-save-mail-hook nil
-  "Hook run narrowed to an article before saving.")
+  "*Hook run narrowed to an article before saving.")
 
 (defvoo nnmh-be-safe nil
-  "If non-nil, nnmh will check all articles to make sure whether they are new or not.
-Go through the .nnmh-articles file and compare with the actual
-articles in this folder.  The articles that are \"new\" will be marked
-as unread by Gnus.")
+  "*If non-nil, nnmh will check all articles to make sure whether they are new or not.")
 
 \f
 
@@ -65,10 +60,7 @@ as unread by Gnus.")
 
 (defvoo nnmh-status-string "")
 (defvoo nnmh-group-alist nil)
-;; Don't even think about setting this variable.  It does not exist.
-;; Forget about it.  Uh-huh.  Nope.  Nobody here.  It's only bound
-;; dynamically by certain functions in nndraft.
-(defvar nnmh-allow-delete-final nil)
+(defvoo nnmh-allow-delete-final nil)
 
 \f
 
@@ -85,7 +77,7 @@ as unread by Gnus.")
           (large (and (numberp nnmail-large-newsgroup)
                       (> number nnmail-large-newsgroup)))
           (count 0)
-          (file-name-coding-system nnmail-pathname-coding-system)
+          (pathname-coding-system 'binary)
           beg article)
       (nnmh-possibly-change-directory newsgroup server)
       ;; We don't support fetching by Message-ID.
@@ -113,7 +105,7 @@ as unread by Gnus.")
          (and large
               (zerop (% count 20))
               (nnheader-message 5 "nnmh: Receiving headers... %d%%"
-                                (/ (* count 100) number))))
+                       (/ (* count 100) number))))
 
        (when large
          (nnheader-message 5 "nnmh: Receiving headers...done"))
@@ -144,7 +136,7 @@ as unread by Gnus.")
   (let ((file (if (stringp id)
                  nil
                (concat nnmh-current-directory (int-to-string id))))
-       (file-name-coding-system nnmail-pathname-coding-system)
+       (pathname-coding-system 'binary)
        (nntp-server-buffer (or buffer nntp-server-buffer)))
     (and (stringp file)
         (file-exists-p file)
@@ -156,7 +148,7 @@ as unread by Gnus.")
   (nnheader-init-server-buffer)
   (nnmh-possibly-change-directory group server)
   (let ((pathname (nnmail-group-pathname group nnmh-directory))
-       (file-name-coding-system nnmail-pathname-coding-system)
+       (pathname-coding-system 'binary)
        dir)
     (cond
      ((not (file-directory-p pathname))
@@ -179,19 +171,16 @@ as unread by Gnus.")
               (mapcar (lambda (name) (string-to-int name))
                       (directory-files pathname nil "^[0-9]+$" t))
               '<))
-       (cond
-        (dir
-         (setq nnmh-group-alist
-               (delq (assoc group nnmh-group-alist) nnmh-group-alist))
-         (push (list group (cons (car dir) (car (last dir))))
-               nnmh-group-alist)
-         (nnheader-report 'nnmh "Selected group %s" group)
-         (nnheader-insert
-          "211 %d %d %d %s\n" (length dir) (car dir)
-          (car (last dir)) group))
-        (t
-         (nnheader-report 'nnmh "Empty group %s" group)
-         (nnheader-insert (format "211 0 1 0 %s\n" group))))))))))
+         (cond
+          (dir
+           (nnheader-report 'nnmh "Selected group %s" group)
+           (nnheader-insert
+            "211 %d %d %d %s\n" (length dir) (car dir)
+            (progn (while (cdr dir) (setq dir (cdr dir))) (car dir))
+            group))
+          (t
+           (nnheader-report 'nnmh "Empty group %s" group)
+           (nnheader-insert (format "211 0 1 0 %s\n" group))))))))))
 
 (deffoo nnmh-request-scan (&optional group server)
   (nnmail-get-new-mail 'nnmh nil nnmh-directory group))
@@ -199,7 +188,7 @@ as unread by Gnus.")
 (deffoo nnmh-request-list (&optional server dir)
   (nnheader-insert "")
   (nnmh-possibly-change-directory nil server)
-  (let ((file-name-coding-system nnmail-pathname-coding-system)
+  (let ((pathname-coding-system 'binary)
        (nnmh-toplev
         (file-truename (or dir (file-name-as-directory nnmh-directory)))))
     (nnmh-request-list-1 nnmh-toplev))
@@ -239,12 +228,10 @@ as unread by Gnus.")
                (file-truename (file-name-as-directory
                                (expand-file-name nnmh-toplev))))
               dir)
-             (mm-string-as-multibyte
-              (mm-encode-coding-string
-               (nnheader-replace-chars-in-string
-                (substring dir (match-end 0))
-                ?/ ?.)
-               nnmail-pathname-coding-system)))
+             (nnheader-replace-chars-in-string
+              (gnus-decode-coding-string (substring dir (match-end 0))
+                                         nnmail-pathname-coding-system)
+              ?/ ?.))
            (apply 'max files)
            (apply 'min files)))))))
   t)
@@ -267,13 +254,6 @@ as unread by Gnus.")
                 (setq is-old
                       (nnmail-expired-article-p newsgroup mod-time force)))
            (progn
-             ;; Allow a special target group. -- jcn
-             (unless (eq nnmail-expiry-target 'delete)
-               (with-temp-buffer
-                 (nnmh-request-article (car articles)
-                                       newsgroup server (current-buffer))
-                 (nnmail-expiry-target-group
-                  nnmail-expiry-target newsgroup)))
              (nnheader-message 5 "Deleting article %s in %s..."
                                article newsgroup)
              (condition-case ()
@@ -291,7 +271,7 @@ as unread by Gnus.")
   t)
 
 (deffoo nnmh-request-move-article
-    (article group server accept-form &optional last)
+  (article group server accept-form &optional last)
   (let ((buf (get-buffer-create " *nnmh move*"))
        result)
     (and
@@ -421,10 +401,10 @@ as unread by Gnus.")
     (nnmh-open-server server))
   (when newsgroup
     (let ((pathname (nnmail-group-pathname newsgroup nnmh-directory))
-         (file-name-coding-system nnmail-pathname-coding-system))
+         (pathname-coding-system 'binary))
       (if (file-directory-p pathname)
          (setq nnmh-current-directory pathname)
-       (nnheader-report 'nnmh "Not a directory: %s" nnmh-directory)))))
+       (error "No such newsgroup: %s" newsgroup)))))
 
 (defun nnmh-possibly-create-directory (group)
   (let (dir dirs)
@@ -470,8 +450,7 @@ as unread by Gnus.")
   "Compute the next article number in GROUP."
   (let ((active (cadr (assoc group nnmh-group-alist)))
        (dir (nnmail-group-pathname group nnmh-directory))
-       (file-name-coding-system nnmail-pathname-coding-system)
-       file)
+       (pathname-coding-system 'binary))
     (unless active
       ;; The group wasn't known to nnmh, so we just create an active
       ;; entry for it.
@@ -489,15 +468,9 @@ as unread by Gnus.")
        (when files
          (setcdr active (car files)))))
     (setcdr active (1+ (cdr active)))
-    (while (or
-           ;; See whether the file exists...
-           (file-exists-p
-            (setq file (concat (nnmail-group-pathname group nnmh-directory)
-                               (int-to-string (cdr active)))))
-           ;; ... or there is a buffer that will make that file exist
-           ;; in the future.
-           (get-file-buffer file))
-      ;; Skip past that file.
+    (while (file-exists-p
+           (concat (nnmail-group-pathname group nnmh-directory)
+                   (int-to-string (cdr active))))
       (setcdr active (1+ (cdr active))))
     (cdr active)))
 
@@ -560,7 +533,7 @@ as unread by Gnus.")
     (setq articles (sort articles (lambda (art1 art2)
                                    (> (car art1) (car art2)))))
     ;; Finally write this list back to the .nnmh-articles file.
-    (with-temp-file nnmh-file
+    (nnheader-temp-write nnmh-file
       (insert ";; Gnus article active file for " group "\n\n")
       (insert "(setq nnmh-newsgroup-articles '")
       (gnus-prin1 articles)