changeset 101346:99d8b439eca6

pmailhdr.el: File removed.
author Chong Yidong <cyd@stupidchicken.com>
date Thu, 22 Jan 2009 04:56:40 +0000
parents cab16dfe3737
children d1ba3386e97a
files lisp/mail/pmailhdr.el
diffstat 1 files changed, 0 insertions(+), 202 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/mail/pmailhdr.el	Thu Jan 22 04:54:35 2009 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,202 +0,0 @@
-;;; pmail-header.el --- Header handling code of "PMAIL" mail reader for Emacs
-
-;; Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
-;;   Free Software Foundation, Inc.
-
-;; Maintainer: FSF
-;; Keywords: mail
-
-;; This file is part of GNU Emacs.
-
-;; GNU Emacs is free software: you can redistribute it and/or modify
-;; it under the terms of the GNU General Public License as published by
-;; the Free Software Foundation, either version 3 of the License, or
-;; (at your option) any later version.
-
-;; GNU Emacs is distributed in the hope that it will be useful,
-;; but WITHOUT ANY WARRANTY; without even the implied warranty of
-;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-;; GNU General Public License for more details.
-
-;; You should have received a copy of the GNU General Public License
-;; along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.
-
-;;; Commentary:
-
-;;; Code:
-
-(eval-when-compile
-  (require 'mail-utils))
-
-(defconst pmail-header-attribute-header "X-BABYL-V6-ATTRIBUTES"
-  "The header that stores the Pmail attribute data.")
-
-(defconst pmail-header-keyword-header "X-BABYL-V6-KEYWORDS"
-  "The header that stores the Pmail keyword data.")
-
-(defvar pmail-header-overlay-list nil
-  "List of cached overlays used to make headers hidden or visible.")
-
-(defvar pmail-header-display-state nil
-  "Records the current header display state.
-nil means headers are displayed, t indicates headers are not displayed.")
-
-(defun pmail-header-get-limit ()
-  "Return the end of the headers.
-The current buffer must show one message.  If you want to narrow
-to the headers of a mail by number, use `pmail-narrow-to-header'
-instead."
-  (save-excursion
-    (goto-char (point-min))
-    (if (search-forward "\n\n" nil t)
-	(1- (point))
-      (error "Invalid message format"))))
-
-(defun pmail-header-add-header (header value)
-  "Add HEADER to the list of headers and associate VALUE with it.
-The current buffer, possibly narrowed, contains a single message.
-If VALUE is nil or the empty string, the header is removed
-instead."
-  (save-excursion
-    (let* ((inhibit-read-only t)
-	   (case-fold-search t)
-	   (inhibit-point-motion-hooks t)
-	   (buffer-undo-list t)
-	   (limit (pmail-header-get-limit))
-	   start end)
-      ;; Search for the given header.  If found, then set it's value.
-      ;; If not then add the header to the end of the header section.
-      (goto-char (point-min))
-      (if (re-search-forward (format "^%s: " header) limit t)
-	  (let ((start (match-beginning 0)))
-	    (re-search-forward "\n[^ \t]")
-	    (goto-char limit)
-	    (delete-region start (1+ (match-beginning 0))))
-	(goto-char limit))
-      (when (> (length value) 0)
-	(insert header ": " value "\n")))))
-
-(defun pmail-header-contains-keyword-p (keyword)
-  "Return t if KEYWORD exists in the current buffer, nil otherwise."
-  (let ((limit (pmail-header-get-limit)))
-    (goto-char (point-min))
-    (if (re-search-forward (format "^%s: " pmail-header-keyword-header) limit t)
-        ;; Some keywords exist.  Now search for the specific keyword.
-        (let ((start (point))
-              (end (progn (end-of-line) (point))))
-          (if (re-search-forward (concat "\\(" keyword ",\\|" keyword "$\\)"))
-              t)))))
-
-(defun pmail-header-get-header (&rest args)
-  "Return the text value for a header or nil if no such header exists.
-The arguments ARGS are passed to `mail-fetch-field'.  The first
-argument is the header to get.
-
-The current buffer, possibly narrowed, contains a single message.
-Note that it is not necessary to call `pmail-header-show-headers'
-because `inhibit-point-motion-hooks' is locally bound to t."
-  (save-excursion
-    (save-restriction
-      (let* ((inhibit-point-motion-hooks t)
-	     (limit (pmail-header-get-limit)))
-	(narrow-to-region (point-min) limit)
-	(apply 'mail-fetch-field args)))))
-
-(defun pmail-header-get-keywords ()
-  "Return the keywords in the current message.
-The current buffer, possibly narrowed, contains a single message."
-  ;; Search for a keyword header and return the comma separated
-  ;; strings as a list.
-  (let ((limit (pmail-header-get-limit)) result)
-    (goto-char (point-min))
-    (if (re-search-forward
-         (format "^%s: " pmail-header-keyword-header) limit t)
-        (save-excursion
-          (save-restriction
-            (narrow-to-region (point) (line-end-position))
-            (goto-char (point-min))
-            (mail-parse-comma-list))))))
-
-(defun pmail-header-hide-headers ()
-  "Hide ignored headers.  All others will be visible.
-The current buffer, possibly narrowed, contains a single message."
-  (save-excursion
-    (pmail-header-show-headers)
-    (let ((overlay-list pmail-header-overlay-list)
-	  (limit (pmail-header-get-limit))
-	  (inhibit-point-motion-hooks t)
-	  (case-fold-search t)
-	  visibility-p)
-      ;; Record the display state as having headers hidden.
-      (setq pmail-header-display-state t)
-      (if pmail-displayed-headers
-	  ;; Set the visibility predicate function to ignore headers
-	  ;; marked for display.
-	  (setq visibility-p 'pmail-header-show-displayed-p)
-	;; Set the visibility predicate function to hide ignored
-	;; headers.
-	(setq visibility-p 'pmail-header-hide-ignored-p))
-      ;; Walk through all the headers marking the non-displayed
-      ;; headers as invisible.
-      (goto-char (point-min))
-      (while (re-search-forward "^[^ \t:]+[ :]" limit t)
-	;; Determine if the current header needs to be hidden.
-	(forward-line 0)
-	(if (not (funcall visibility-p))
-	    ;; It does not.  Move point away from this header.
-	    (progn
-	      (forward-line 1)
-	      (while (looking-at "[ \t]+")
-		(forward-line 1)))
-	  ;; It does.  Make this header hidden by setting an overlay
-	  ;; with both the invisible and intangible properties set.
-	  (let ((start (point)))
-	    ;; Move to end and pick upp any continuation lines on folded
-	    ;; headers.
-	    (forward-line 1)
-	    (while (looking-at "[ \t]+")
-	      (forward-line 1))
-	    (if (car overlay-list)
-		;; Use one of the cleared, cached overlays.
-		(let ((overlay (car overlay-list)))
-		  (move-overlay overlay start (point))
-		  (setq overlay-list (cdr overlay-list)))
-	      ;; No overlay exists for this header.  Create one and
-	      ;; add it to the cache.
-	      (let ((overlay (make-overlay start (point))))
-		(overlay-put overlay 'invisible t)
-		(overlay-put overlay 'intangible t)
-		(push overlay pmail-header-overlay-list)))))))))
-
-(defun pmail-header-show-headers ()
-  "Show all headers.
-The current buffer, possibly narrowed, contains a single message."
-  ;; Remove all the overlays used to control hiding headers.
-  (mapc 'delete-overlay pmail-header-overlay-list)
-  (setq pmail-header-display-state nil))
-
-(defun pmail-header-toggle-visibility (&optional arg)
-  "Toggle the visibility of the ignored headers if ARG is nil.
-Hide the ignored headers if ARG is greater than 0, otherwise show the
-ignored headers.  The current buffer, possibly narrowed, contains a
-single message."
-  (cond ((eq arg nil)
-	 (if pmail-header-display-state
-	     (pmail-header-show-headers)
-	   (pmail-header-hide-headers)))
-	((or (eq arg t) (> arg 0))
-	 (pmail-header-hide-headers))
-	(t (pmail-header-show-headers))))
-
-(defun pmail-header-hide-ignored-p ()
-  "Test that the header is one of the headers marked to be ignored."
-  (looking-at pmail-ignored-headers))
-
-(defun pmail-header-show-displayed-p ()
-  "Test that the header is not one of the headers marked for display."
-  (not (looking-at pmail-displayed-headers)))
-
-(provide 'pmailhdr)
-
-;; arch-tag: d708a0d9-2686-4958-b61a-7d3d2ace2131
-;;; pmailhdr.el ends here