1993-03-17 17:17:05 +00:00
|
|
|
|
;;; rmailsum.el --- make summary buffers for the mail reader
|
1993-03-17 16:56:02 +00:00
|
|
|
|
|
2001-03-12 15:58:05 +00:00
|
|
|
|
;; Copyright (C) 1985, 1993, 1994, 1995, 1996, 2000, 2001
|
2000-04-03 19:25:08 +00:00
|
|
|
|
;; Free Software Foundation, Inc.
|
1992-07-22 04:22:30 +00:00
|
|
|
|
|
1992-07-16 21:47:34 +00:00
|
|
|
|
;; Maintainer: FSF
|
1992-07-17 20:24:00 +00:00
|
|
|
|
;; Keywords: mail
|
1992-07-16 21:47:34 +00:00
|
|
|
|
|
1990-11-30 22:29:57 +00:00
|
|
|
|
;; 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
|
1992-07-16 21:47:34 +00:00
|
|
|
|
;; the Free Software Foundation; either version 2, or (at your option)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
;; 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
|
1996-01-14 07:34:30 +00:00
|
|
|
|
;; along with GNU Emacs; see the file COPYING. If not, write to the
|
|
|
|
|
;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
|
;; Boston, MA 02111-1307, USA.
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1993-03-17 16:56:02 +00:00
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; Extended by Bob Weiner of Motorola
|
|
|
|
|
;; Provided all commands from rmail-mode in rmail-summary-mode and made key
|
|
|
|
|
;; bindings in both modes wholly compatible.
|
|
|
|
|
|
1993-03-17 16:56:02 +00:00
|
|
|
|
;;; Code:
|
|
|
|
|
|
1995-08-21 14:48:49 +00:00
|
|
|
|
;; For rmail-select-summary
|
|
|
|
|
(require 'rmail)
|
|
|
|
|
|
1996-04-04 17:01:45 +00:00
|
|
|
|
;;;###autoload
|
1997-05-03 19:16:43 +00:00
|
|
|
|
(defcustom rmail-summary-scroll-between-messages t
|
|
|
|
|
"*Non-nil means Rmail summary scroll commands move between messages."
|
|
|
|
|
:type 'boolean
|
|
|
|
|
:group 'rmail-summary)
|
1996-04-04 17:01:45 +00:00
|
|
|
|
|
1996-10-04 18:39:31 +00:00
|
|
|
|
;;;###autoload
|
1997-05-03 19:16:43 +00:00
|
|
|
|
(defcustom rmail-summary-line-count-flag t
|
2003-02-06 22:02:35 +00:00
|
|
|
|
"*Non-nil means Rmail summary should show the number of lines in each message."
|
1997-05-03 19:16:43 +00:00
|
|
|
|
:type 'boolean
|
|
|
|
|
:group 'rmail-summary)
|
1996-10-04 18:39:31 +00:00
|
|
|
|
|
1994-10-07 09:56:40 +00:00
|
|
|
|
(defvar rmail-summary-font-lock-keywords
|
2001-10-21 19:08:56 +00:00
|
|
|
|
'(("^.....D.*" . font-lock-string-face) ; Deleted.
|
|
|
|
|
("^.....-.*" . font-lock-type-face) ; Unread.
|
1994-10-07 09:56:40 +00:00
|
|
|
|
;; Neither of the below will be highlighted if either of the above are:
|
2001-10-21 19:08:56 +00:00
|
|
|
|
("^.....[^D-] \\(......\\)" 1 font-lock-keyword-face) ; Date.
|
2003-09-30 12:43:49 +00:00
|
|
|
|
("{ \\([^\n}]+\\) }" 1 font-lock-comment-face)) ; Labels.
|
1994-10-07 09:56:40 +00:00
|
|
|
|
"Additional expressions to highlight in Rmail Summary mode.")
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; Entry points for making a summary buffer.
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; Regenerate the contents of the summary
|
|
|
|
|
;; using the same selection criterion as last time.
|
|
|
|
|
;; M-x revert-buffer in a summary buffer calls this function.
|
|
|
|
|
(defun rmail-update-summary (&rest ignore)
|
|
|
|
|
(apply (car rmail-summary-redo) (cdr rmail-summary-redo)))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1996-09-27 00:25:55 +00:00
|
|
|
|
;;;###autoload
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-summary ()
|
|
|
|
|
"Display a summary of all messages, one line per message."
|
|
|
|
|
(interactive)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(rmail-new-summary "All" '(rmail-summary) nil))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1996-09-27 00:25:55 +00:00
|
|
|
|
;;;###autoload
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-summary-by-labels (labels)
|
|
|
|
|
"Display a summary of all messages with one or more LABELS.
|
|
|
|
|
LABELS should be a string containing the desired labels, separated by commas."
|
|
|
|
|
(interactive "sLabels to summarize by: ")
|
|
|
|
|
(if (string= labels "")
|
|
|
|
|
(setq labels (or rmail-last-multi-labels
|
|
|
|
|
(error "No label specified"))))
|
|
|
|
|
(setq rmail-last-multi-labels labels)
|
|
|
|
|
(rmail-new-summary (concat "labels " labels)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(list 'rmail-summary-by-labels labels)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
'rmail-message-labels-p
|
|
|
|
|
(concat ", \\(" (mail-comma-list-regexp labels) "\\),")))
|
|
|
|
|
|
1996-09-27 00:25:55 +00:00
|
|
|
|
;;;###autoload
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-summary-by-recipients (recipients &optional primary-only)
|
|
|
|
|
"Display a summary of all messages with the given RECIPIENTS.
|
|
|
|
|
Normally checks the To, From and Cc fields of headers;
|
|
|
|
|
but if PRIMARY-ONLY is non-nil (prefix arg given),
|
|
|
|
|
only look in the To and From fields.
|
1993-03-09 08:08:52 +00:00
|
|
|
|
RECIPIENTS is a string of regexps separated by commas."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive "sRecipients to summarize by: \nP")
|
|
|
|
|
(rmail-new-summary
|
|
|
|
|
(concat "recipients " recipients)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(list 'rmail-summary-by-recipients recipients primary-only)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
'rmail-message-recipients-p
|
|
|
|
|
(mail-comma-list-regexp recipients) primary-only))
|
|
|
|
|
|
1996-09-27 00:25:55 +00:00
|
|
|
|
;;;###autoload
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-summary-by-regexp (regexp)
|
|
|
|
|
"Display a summary of all messages according to regexp REGEXP.
|
|
|
|
|
If the regular expression is found in the header of the message
|
|
|
|
|
\(including in the date and other lines, as well as the subject line),
|
|
|
|
|
Emacs will list the header line in the RMAIL-summary."
|
|
|
|
|
(interactive "sRegexp to summarize by: ")
|
|
|
|
|
(if (string= regexp "")
|
|
|
|
|
(setq regexp (or rmail-last-regexp
|
2001-07-15 16:15:35 +00:00
|
|
|
|
(error "No regexp specified"))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(setq rmail-last-regexp regexp)
|
|
|
|
|
(rmail-new-summary (concat "regexp " regexp)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(list 'rmail-summary-by-regexp regexp)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
'rmail-message-regexp-p
|
|
|
|
|
regexp))
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; rmail-summary-by-topic
|
|
|
|
|
;; 1989 R.A. Schnitzler
|
|
|
|
|
|
1996-09-27 00:25:55 +00:00
|
|
|
|
;;;###autoload
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-by-topic (subject &optional whole-message)
|
|
|
|
|
"Display a summary of all messages with the given SUBJECT.
|
|
|
|
|
Normally checks the Subject field of headers;
|
2003-02-04 13:24:35 +00:00
|
|
|
|
but if WHOLE-MESSAGE is non-nil (prefix arg given),
|
1993-03-09 08:08:52 +00:00
|
|
|
|
look in the whole message.
|
|
|
|
|
SUBJECT is a string of regexps separated by commas."
|
|
|
|
|
(interactive "sTopics to summarize by: \nP")
|
|
|
|
|
(rmail-new-summary
|
|
|
|
|
(concat "about " subject)
|
|
|
|
|
(list 'rmail-summary-by-topic subject whole-message)
|
|
|
|
|
'rmail-message-subject-p
|
|
|
|
|
(mail-comma-list-regexp subject) whole-message))
|
|
|
|
|
|
|
|
|
|
(defun rmail-message-subject-p (msg subject &optional whole-message)
|
|
|
|
|
(save-restriction
|
|
|
|
|
(goto-char (rmail-msgbeg msg))
|
1998-11-01 18:55:11 +00:00
|
|
|
|
(search-forward "\n*** EOOH ***\n" (rmail-msgend msg) 'move)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(narrow-to-region
|
|
|
|
|
(point)
|
1993-05-31 17:04:52 +00:00
|
|
|
|
(progn (search-forward (if whole-message "\^_" "\n\n")) (point)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(goto-char (point-min))
|
|
|
|
|
(if whole-message (re-search-forward subject nil t)
|
2001-05-31 08:08:41 +00:00
|
|
|
|
(string-match subject (let ((subj (mail-fetch-field "Subject")))
|
|
|
|
|
(if subj
|
|
|
|
|
(funcall rmail-summary-line-decoder subj)
|
|
|
|
|
""))))))
|
1993-06-03 04:48:56 +00:00
|
|
|
|
|
1996-09-27 00:25:55 +00:00
|
|
|
|
;;;###autoload
|
1993-06-03 04:48:56 +00:00
|
|
|
|
(defun rmail-summary-by-senders (senders)
|
|
|
|
|
"Display a summary of all messages with the given SENDERS.
|
|
|
|
|
SENDERS is a string of names separated by commas."
|
|
|
|
|
(interactive "sSenders to summarize by: ")
|
|
|
|
|
(rmail-new-summary
|
|
|
|
|
(concat "senders " senders)
|
1994-01-08 11:48:18 +00:00
|
|
|
|
(list 'rmail-summary-by-senders senders)
|
1993-06-03 04:48:56 +00:00
|
|
|
|
'rmail-message-senders-p
|
|
|
|
|
(mail-comma-list-regexp senders)))
|
|
|
|
|
|
|
|
|
|
(defun rmail-message-senders-p (msg senders)
|
|
|
|
|
(save-restriction
|
|
|
|
|
(goto-char (rmail-msgbeg msg))
|
|
|
|
|
(search-forward "\n*** EOOH ***\n")
|
|
|
|
|
(narrow-to-region (point) (progn (search-forward "\n\n") (point)))
|
|
|
|
|
(string-match senders (or (mail-fetch-field "From") ""))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; General making of a summary buffer.
|
|
|
|
|
|
|
|
|
|
(defvar rmail-summary-symbol-number 0)
|
|
|
|
|
|
|
|
|
|
(defun rmail-new-summary (description redo-form function &rest args)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
"Create a summary of selected messages.
|
|
|
|
|
DESCRIPTION makes part of the mode line of the summary buffer.
|
|
|
|
|
For each message, FUNCTION is applied to the message number and ARGS...
|
|
|
|
|
and if the result is non-nil, that message is included.
|
|
|
|
|
nil for FUNCTION means all messages."
|
|
|
|
|
(message "Computing summary lines...")
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(let (sumbuf mesg was-in-summary)
|
|
|
|
|
(save-excursion
|
|
|
|
|
;; Go to the Rmail buffer.
|
|
|
|
|
(if (eq major-mode 'rmail-summary-mode)
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(setq was-in-summary t))
|
|
|
|
|
(set-buffer rmail-buffer)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; Find its summary buffer, or make one.
|
1993-05-28 04:44:55 +00:00
|
|
|
|
(setq sumbuf
|
|
|
|
|
(if (and rmail-summary-buffer
|
|
|
|
|
(buffer-name rmail-summary-buffer))
|
|
|
|
|
rmail-summary-buffer
|
|
|
|
|
(generate-new-buffer (concat (buffer-name) "-summary"))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(setq mesg rmail-current-message)
|
|
|
|
|
;; Filter the messages; make or get their summary lines.
|
|
|
|
|
(let ((summary-msgs ())
|
|
|
|
|
(new-summary-line-count 0))
|
|
|
|
|
(let ((msgnum 1)
|
1994-04-09 02:46:19 +00:00
|
|
|
|
(buffer-read-only nil)
|
|
|
|
|
(old-min (point-min-marker))
|
|
|
|
|
(old-max (point-max-marker)))
|
|
|
|
|
;; Can't use save-restriction here; that doesn't work if we
|
|
|
|
|
;; plan to modify text outside the original restriction.
|
|
|
|
|
(save-excursion
|
|
|
|
|
(widen)
|
|
|
|
|
(goto-char (point-min))
|
|
|
|
|
(while (>= rmail-total-messages msgnum)
|
|
|
|
|
(if (or (null function)
|
|
|
|
|
(apply function (cons msgnum args)))
|
|
|
|
|
(setq summary-msgs
|
|
|
|
|
(cons (cons msgnum (rmail-make-summary-line msgnum))
|
|
|
|
|
summary-msgs)))
|
|
|
|
|
(setq msgnum (1+ msgnum)))
|
|
|
|
|
(setq summary-msgs (nreverse summary-msgs)))
|
|
|
|
|
(narrow-to-region old-min old-max))
|
1993-05-28 04:44:55 +00:00
|
|
|
|
;; Temporarily, while summary buffer is unfinished,
|
|
|
|
|
;; we "don't have" a summary.
|
|
|
|
|
(setq rmail-summary-buffer nil)
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(if rmail-enable-mime
|
|
|
|
|
(with-current-buffer rmail-view-buffer
|
|
|
|
|
(setq rmail-summary-buffer nil)))
|
1993-05-28 04:44:55 +00:00
|
|
|
|
(save-excursion
|
|
|
|
|
(let ((rbuf (current-buffer))
|
1997-02-26 13:05:13 +00:00
|
|
|
|
(vbuf rmail-view-buffer)
|
1993-05-28 04:44:55 +00:00
|
|
|
|
(total rmail-total-messages))
|
|
|
|
|
(set-buffer sumbuf)
|
|
|
|
|
;; Set up the summary buffer's contents.
|
|
|
|
|
(let ((buffer-read-only nil))
|
|
|
|
|
(erase-buffer)
|
|
|
|
|
(while summary-msgs
|
|
|
|
|
(princ (cdr (car summary-msgs)) sumbuf)
|
|
|
|
|
(setq summary-msgs (cdr summary-msgs)))
|
|
|
|
|
(goto-char (point-min)))
|
|
|
|
|
;; Set up the rest of its state and local variables.
|
|
|
|
|
(setq buffer-read-only t)
|
|
|
|
|
(rmail-summary-mode)
|
|
|
|
|
(make-local-variable 'minor-mode-alist)
|
1996-06-12 03:13:51 +00:00
|
|
|
|
(setq minor-mode-alist (list (list t (concat ": " description))))
|
1993-05-28 04:44:55 +00:00
|
|
|
|
(setq rmail-buffer rbuf
|
1997-02-26 13:05:13 +00:00
|
|
|
|
rmail-view-buffer vbuf
|
1993-05-28 04:44:55 +00:00
|
|
|
|
rmail-summary-redo redo-form
|
|
|
|
|
rmail-total-messages total))))
|
|
|
|
|
(setq rmail-summary-buffer sumbuf))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; Now display the summary buffer and go to the right place in it.
|
|
|
|
|
(or was-in-summary
|
1995-08-21 14:48:49 +00:00
|
|
|
|
(progn
|
|
|
|
|
(if (and (one-window-p)
|
|
|
|
|
pop-up-windows (not pop-up-frames))
|
|
|
|
|
;; If there is just one window, put the summary on the top.
|
|
|
|
|
(progn
|
|
|
|
|
(split-window (selected-window) rmail-summary-window-size)
|
|
|
|
|
(select-window (next-window (frame-first-window)))
|
|
|
|
|
(pop-to-buffer sumbuf)
|
|
|
|
|
;; If pop-to-buffer did not use that window, delete that
|
|
|
|
|
;; window. (This can happen if it uses another frame.)
|
|
|
|
|
(if (not (eq sumbuf (window-buffer (frame-first-window))))
|
|
|
|
|
(delete-other-windows)))
|
|
|
|
|
(pop-to-buffer sumbuf))
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
;; This is how rmail makes the summary buffer reappear.
|
|
|
|
|
;; We do this here to make the window the proper size.
|
|
|
|
|
(rmail-select-summary nil)
|
|
|
|
|
(set-buffer rmail-summary-buffer)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(rmail-summary-goto-msg mesg t t)
|
1995-08-17 16:51:57 +00:00
|
|
|
|
(rmail-summary-construct-io-menu)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(message "Computing summary lines...done")))
|
|
|
|
|
|
|
|
|
|
;; Low levels of generating a summary.
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-make-summary-line (msg)
|
|
|
|
|
(let ((line (or (aref rmail-summary-vector (1- msg))
|
|
|
|
|
(progn
|
|
|
|
|
(setq new-summary-line-count
|
|
|
|
|
(1+ new-summary-line-count))
|
|
|
|
|
(if (zerop (% new-summary-line-count 10))
|
|
|
|
|
(message "Computing summary lines...%d"
|
|
|
|
|
new-summary-line-count))
|
|
|
|
|
(rmail-make-summary-line-1 msg)))))
|
|
|
|
|
;; Fix up the part of the summary that says "deleted" or "unseen".
|
2001-10-05 09:35:36 +00:00
|
|
|
|
(aset line 5
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(if (rmail-message-deleted-p msg) ?\D
|
|
|
|
|
(if (= ?0 (char-after (+ 3 (rmail-msgbeg msg))))
|
|
|
|
|
?\- ?\ )))
|
|
|
|
|
line))
|
|
|
|
|
|
1997-02-26 13:05:13 +00:00
|
|
|
|
;;;###autoload
|
1997-05-03 19:16:43 +00:00
|
|
|
|
(defcustom rmail-summary-line-decoder (function identity)
|
1997-02-26 13:05:13 +00:00
|
|
|
|
"*Function to decode summary-line.
|
|
|
|
|
|
1997-05-03 19:16:43 +00:00
|
|
|
|
By default, `identity' is set."
|
|
|
|
|
:type 'function
|
|
|
|
|
:group 'rmail-summary)
|
1997-02-26 13:05:13 +00:00
|
|
|
|
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-make-summary-line-1 (msg)
|
|
|
|
|
(goto-char (rmail-msgbeg msg))
|
|
|
|
|
(let* ((lim (save-excursion (forward-line 2) (point)))
|
|
|
|
|
pos
|
|
|
|
|
(labels
|
|
|
|
|
(progn
|
|
|
|
|
(forward-char 3)
|
|
|
|
|
(concat
|
|
|
|
|
; (if (save-excursion (re-search-forward ",answered," lim t))
|
|
|
|
|
; "*" "")
|
|
|
|
|
; (if (save-excursion (re-search-forward ",filed," lim t))
|
|
|
|
|
; "!" "")
|
|
|
|
|
(if (progn (search-forward ",,") (eolp))
|
|
|
|
|
""
|
|
|
|
|
(concat "{"
|
|
|
|
|
(buffer-substring (point)
|
2003-09-30 12:43:49 +00:00
|
|
|
|
(progn (end-of-line)
|
|
|
|
|
(backward-char)
|
|
|
|
|
(if (looking-at ",")
|
|
|
|
|
(point)
|
|
|
|
|
(1+ (point)))))
|
|
|
|
|
" } ")))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(line
|
|
|
|
|
(progn
|
|
|
|
|
(forward-line 1)
|
|
|
|
|
(if (looking-at "Summary-line: ")
|
|
|
|
|
(progn
|
|
|
|
|
(goto-char (match-end 0))
|
|
|
|
|
(setq line
|
|
|
|
|
(buffer-substring (point)
|
|
|
|
|
(progn (forward-line 1) (point)))))))))
|
|
|
|
|
;; Obsolete status lines lacking a # should be flushed.
|
|
|
|
|
(and line
|
|
|
|
|
(not (string-match "#" line))
|
|
|
|
|
(progn
|
|
|
|
|
(delete-region (point)
|
|
|
|
|
(progn (forward-line -1) (point)))
|
|
|
|
|
(setq line nil)))
|
|
|
|
|
;; If we didn't get a valid status line from the message,
|
|
|
|
|
;; make a new one and put it in the message.
|
|
|
|
|
(or line
|
|
|
|
|
(let* ((case-fold-search t)
|
|
|
|
|
(next (rmail-msgend msg))
|
|
|
|
|
(beg (if (progn (goto-char (rmail-msgbeg msg))
|
|
|
|
|
(search-forward "\n*** EOOH ***\n" next t))
|
|
|
|
|
(point)
|
|
|
|
|
(forward-line 1)
|
|
|
|
|
(point)))
|
|
|
|
|
(end (progn (search-forward "\n\n" nil t) (point))))
|
|
|
|
|
(save-restriction
|
|
|
|
|
(narrow-to-region beg end)
|
|
|
|
|
(goto-char beg)
|
|
|
|
|
(setq line (rmail-make-basic-summary-line)))
|
|
|
|
|
(goto-char (rmail-msgbeg msg))
|
|
|
|
|
(forward-line 2)
|
|
|
|
|
(insert "Summary-line: " line)))
|
|
|
|
|
(setq pos (string-match "#" line))
|
|
|
|
|
(aset rmail-summary-vector (1- msg)
|
1997-02-26 13:05:13 +00:00
|
|
|
|
(funcall rmail-summary-line-decoder
|
2001-10-05 09:35:36 +00:00
|
|
|
|
(concat (format "%5d " msg)
|
1997-02-26 13:05:13 +00:00
|
|
|
|
(substring line 0 pos)
|
|
|
|
|
labels
|
|
|
|
|
(substring line (1+ pos)))))
|
|
|
|
|
))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
2000-04-03 19:25:08 +00:00
|
|
|
|
;;;###autoload
|
|
|
|
|
(defcustom rmail-user-mail-address-regexp nil
|
|
|
|
|
"*Regexp matching user mail addresses.
|
|
|
|
|
If non-nil, this variable is used to identify the correspondent
|
|
|
|
|
when receiving new mail. If it matches the address of the sender,
|
|
|
|
|
the recipient is taken as correspondent of a mail.
|
|
|
|
|
If nil \(default value\), your `user-login-name' and `user-mail-address'
|
|
|
|
|
are used to exclude yourself as correspondent.
|
|
|
|
|
|
|
|
|
|
Usually you don't have to set this variable, except if you collect mails
|
|
|
|
|
sent by you under different user names.
|
2002-07-02 14:49:22 +00:00
|
|
|
|
Then it should be a regexp matching your mail addresses.
|
2000-04-03 19:25:08 +00:00
|
|
|
|
|
|
|
|
|
Setting this variable has an effect only before reading a mail."
|
|
|
|
|
:type '(choice (const :tag "None" nil) regexp)
|
|
|
|
|
:group 'rmail-retrieve
|
|
|
|
|
:version "21.1")
|
|
|
|
|
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-make-basic-summary-line ()
|
|
|
|
|
(goto-char (point-min))
|
|
|
|
|
(concat (save-excursion
|
|
|
|
|
(if (not (re-search-forward "^Date:" nil t))
|
|
|
|
|
" "
|
|
|
|
|
(cond ((re-search-forward "\\([^0-9:]\\)\\([0-3]?[0-9]\\)\\([- \t_]+\\)\\([adfjmnos][aceopu][bcglnprtvy]\\)"
|
|
|
|
|
(save-excursion (end-of-line) (point)) t)
|
|
|
|
|
(format "%2d-%3s"
|
|
|
|
|
(string-to-int (buffer-substring
|
|
|
|
|
(match-beginning 2)
|
|
|
|
|
(match-end 2)))
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(match-beginning 4) (match-end 4))))
|
|
|
|
|
((re-search-forward "\\([^a-z]\\)\\([adfjmnos][acepou][bcglnprtvy]\\)\\([-a-z \t_]*\\)\\([0-9][0-9]?\\)"
|
|
|
|
|
(save-excursion (end-of-line) (point)) t)
|
|
|
|
|
(format "%2d-%3s"
|
|
|
|
|
(string-to-int (buffer-substring
|
|
|
|
|
(match-beginning 4)
|
|
|
|
|
(match-end 4)))
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(match-beginning 2) (match-end 2))))
|
1996-07-02 16:23:51 +00:00
|
|
|
|
((re-search-forward "\\(19\\|20\\)\\([0-9][0-9]\\)-\\([01][0-9]\\)-\\([0-3][0-9]\\)"
|
|
|
|
|
(save-excursion (end-of-line) (point)) t)
|
|
|
|
|
(format "%2s%2s%2s"
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(match-beginning 2) (match-end 2))
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(match-beginning 3) (match-end 3))
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(match-beginning 4) (match-end 4))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(t "??????"))))
|
|
|
|
|
" "
|
|
|
|
|
(save-excursion
|
2003-04-09 01:31:31 +00:00
|
|
|
|
(let* ((from (and (re-search-forward "^From:[ \t]*" nil t)
|
|
|
|
|
(mail-strip-quoted-names
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(1- (point))
|
|
|
|
|
;; Get all the lines of the From field
|
|
|
|
|
;; so that we get a whole comment if there is one,
|
|
|
|
|
;; so that mail-strip-quoted-names can discard it.
|
|
|
|
|
(let ((opoint (point)))
|
|
|
|
|
(while (progn (forward-line 1)
|
|
|
|
|
(looking-at "[ \t]")))
|
|
|
|
|
;; Back up over newline, then trailing spaces or tabs
|
|
|
|
|
(forward-char -1)
|
|
|
|
|
(skip-chars-backward " \t")
|
|
|
|
|
(point))))))
|
|
|
|
|
len mch lo)
|
|
|
|
|
(if (or (null from)
|
|
|
|
|
(string-match
|
|
|
|
|
(or rmail-user-mail-address-regexp
|
|
|
|
|
(concat "^\\("
|
|
|
|
|
(regexp-quote (user-login-name))
|
|
|
|
|
"\\($\\|@\\)\\|"
|
|
|
|
|
(regexp-quote
|
|
|
|
|
;; Don't lose if run from init file
|
|
|
|
|
;; where user-mail-address is not
|
|
|
|
|
;; set yet.
|
|
|
|
|
(or user-mail-address
|
|
|
|
|
(concat (user-login-name) "@"
|
|
|
|
|
(or mail-host-address
|
|
|
|
|
(system-name)))))
|
|
|
|
|
"\\>\\)"))
|
|
|
|
|
from))
|
|
|
|
|
;; No From field, or it's this user.
|
|
|
|
|
(save-excursion
|
|
|
|
|
(goto-char (point-min))
|
|
|
|
|
(if (not (re-search-forward "^To:[ \t]*" nil t))
|
|
|
|
|
nil
|
|
|
|
|
(setq from
|
|
|
|
|
(concat "to: "
|
|
|
|
|
(mail-strip-quoted-names
|
|
|
|
|
(buffer-substring
|
|
|
|
|
(point)
|
|
|
|
|
(progn (end-of-line)
|
|
|
|
|
(skip-chars-backward " \t")
|
|
|
|
|
(point)))))))))
|
|
|
|
|
(if (null from)
|
|
|
|
|
" "
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(setq len (length from))
|
|
|
|
|
(setq mch (string-match "[@%]" from))
|
|
|
|
|
(format "%25s"
|
|
|
|
|
(if (or (not mch) (<= len 25))
|
|
|
|
|
(substring from (max 0 (- len 25)))
|
|
|
|
|
(substring from
|
1994-05-06 23:59:28 +00:00
|
|
|
|
(setq lo (cond ((< (- mch 14) 0) 0)
|
|
|
|
|
((< len (+ mch 11))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(- len 25))
|
1994-05-06 23:59:28 +00:00
|
|
|
|
(t (- mch 14))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(min len (+ lo 25))))))))
|
1996-10-04 18:40:55 +00:00
|
|
|
|
(if rmail-summary-line-count-flag
|
1996-10-04 18:39:31 +00:00
|
|
|
|
(save-excursion
|
|
|
|
|
(save-restriction
|
|
|
|
|
(widen)
|
|
|
|
|
(let ((beg (rmail-msgbeg msgnum))
|
|
|
|
|
(end (rmail-msgend msgnum))
|
|
|
|
|
lines)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(goto-char beg)
|
|
|
|
|
;; Count only lines in the reformatted header,
|
|
|
|
|
;; if we have reformatted it.
|
|
|
|
|
(search-forward "\n*** EOOH ***\n" end t)
|
|
|
|
|
(setq lines (count-lines (point) end)))
|
|
|
|
|
(format (cond
|
|
|
|
|
((<= lines 9) " [%d]")
|
|
|
|
|
((<= lines 99) " [%d]")
|
|
|
|
|
((<= lines 999) " [%3d]")
|
|
|
|
|
(t "[%d]"))
|
|
|
|
|
lines))))
|
|
|
|
|
" ")
|
1996-02-26 04:07:44 +00:00
|
|
|
|
" #" ;The # is part of the format.
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(if (re-search-forward "^Subject:" nil t)
|
|
|
|
|
(progn (skip-chars-forward " \t")
|
|
|
|
|
(buffer-substring (point)
|
|
|
|
|
(progn (end-of-line)
|
|
|
|
|
(point))))
|
|
|
|
|
(re-search-forward "[\n][\n]+" nil t)
|
|
|
|
|
(buffer-substring (point) (progn (end-of-line) (point))))
|
|
|
|
|
"\n"))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
;; Simple motion in a summary buffer.
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-next-all (&optional number)
|
|
|
|
|
(interactive "p")
|
1993-03-13 21:52:43 +00:00
|
|
|
|
(forward-line (if number number 1))
|
1994-10-15 10:18:02 +00:00
|
|
|
|
;; It doesn't look nice to move forward past the last message line.
|
|
|
|
|
(and (eobp) (> number 0)
|
|
|
|
|
(forward-line -1))
|
1993-03-13 21:52:43 +00:00
|
|
|
|
(display-buffer rmail-buffer))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-previous-all (&optional number)
|
|
|
|
|
(interactive "p")
|
1993-03-13 21:52:43 +00:00
|
|
|
|
(forward-line (- (if number number 1)))
|
1994-10-15 10:18:02 +00:00
|
|
|
|
;; It doesn't look nice to move forward past the last message line.
|
|
|
|
|
(and (eobp) (< number 0)
|
|
|
|
|
(forward-line -1))
|
1993-03-13 21:52:43 +00:00
|
|
|
|
(display-buffer rmail-buffer))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-next-msg (&optional number)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
"Display next non-deleted msg from rmail file.
|
|
|
|
|
With optional prefix argument NUMBER, moves forward this number of non-deleted
|
|
|
|
|
messages, or backward if NUMBER is negative."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive "p")
|
|
|
|
|
(forward-line 0)
|
1993-06-04 02:24:45 +00:00
|
|
|
|
(and (> number 0) (end-of-line))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(let ((count (if (< number 0) (- number) number))
|
|
|
|
|
(search (if (> number 0) 're-search-forward 're-search-backward))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(non-del-msg-found nil))
|
|
|
|
|
(while (and (> count 0) (setq non-del-msg-found
|
1993-06-05 21:18:11 +00:00
|
|
|
|
(or (funcall search "^....[^D]" nil t)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
non-del-msg-found)))
|
1993-03-13 21:52:43 +00:00
|
|
|
|
(setq count (1- count))))
|
1993-06-04 02:24:45 +00:00
|
|
|
|
(beginning-of-line)
|
2003-02-06 22:02:35 +00:00
|
|
|
|
(display-buffer rmail-view-buffer))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-previous-msg (&optional number)
|
2003-02-06 22:02:35 +00:00
|
|
|
|
"Display previous non-deleted msg from rmail file.
|
|
|
|
|
With optional prefix argument NUMBER, moves backward this number of
|
|
|
|
|
non-deleted messages."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive "p")
|
|
|
|
|
(rmail-summary-next-msg (- (if number number 1))))
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-next-labeled-message (n labels)
|
2003-02-06 22:02:35 +00:00
|
|
|
|
"Show next message with LABELS. Defaults to last labels used.
|
1993-03-09 08:08:52 +00:00
|
|
|
|
With prefix argument N moves forward N messages with these labels."
|
|
|
|
|
(interactive "p\nsMove to next msg with labels: ")
|
1996-07-13 00:57:31 +00:00
|
|
|
|
(let (msg)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-next-labeled-message n labels)
|
|
|
|
|
(setq msg rmail-current-message))
|
|
|
|
|
(rmail-summary-goto-msg msg)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-previous-labeled-message (n labels)
|
2003-02-06 22:02:35 +00:00
|
|
|
|
"Show previous message with LABELS. Defaults to last labels used.
|
1993-03-09 08:08:52 +00:00
|
|
|
|
With prefix argument N moves backward N messages with these labels."
|
|
|
|
|
(interactive "p\nsMove to previous msg with labels: ")
|
1996-07-13 00:57:31 +00:00
|
|
|
|
(let (msg)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-previous-labeled-message n labels)
|
|
|
|
|
(setq msg rmail-current-message))
|
|
|
|
|
(rmail-summary-goto-msg msg)))
|
1995-02-05 02:46:34 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-next-same-subject (n)
|
|
|
|
|
"Go to the next message in the summary having the same subject.
|
|
|
|
|
With prefix argument N, do this N times.
|
|
|
|
|
If N is negative, go backwards."
|
|
|
|
|
(interactive "p")
|
|
|
|
|
(let (subject search-regexp i found
|
|
|
|
|
(forward (> n 0)))
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(setq subject (mail-fetch-field "Subject"))
|
|
|
|
|
(setq i rmail-current-message))
|
|
|
|
|
(if (string-match "Re:[ \t]*" subject)
|
|
|
|
|
(setq subject (substring subject (match-end 0))))
|
1996-09-19 03:22:51 +00:00
|
|
|
|
(setq search-regexp (concat "^Subject: *\\(Re: *\\)?"
|
|
|
|
|
(regexp-quote subject)
|
|
|
|
|
"\n"))
|
1995-02-05 02:46:34 +00:00
|
|
|
|
(save-excursion
|
|
|
|
|
(while (and (/= n 0)
|
|
|
|
|
(if forward
|
|
|
|
|
(not (eobp))
|
|
|
|
|
(not (bobp))))
|
|
|
|
|
(let (done)
|
|
|
|
|
(while (and (not done)
|
|
|
|
|
(if forward
|
|
|
|
|
(not (eobp))
|
|
|
|
|
(not (bobp))))
|
|
|
|
|
;; Advance thru summary.
|
|
|
|
|
(forward-line (if forward 1 -1))
|
|
|
|
|
;; Get msg number of this line.
|
|
|
|
|
(setq i (string-to-int
|
|
|
|
|
(buffer-substring (point)
|
2001-10-05 09:35:36 +00:00
|
|
|
|
(min (point-max) (+ 6 (point))))))
|
1995-02-05 02:46:34 +00:00
|
|
|
|
;; See if that msg has desired subject.
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(save-restriction
|
|
|
|
|
(widen)
|
|
|
|
|
(goto-char (rmail-msgbeg i))
|
|
|
|
|
(search-forward "\n*** EOOH ***\n")
|
|
|
|
|
(let ((beg (point)) end)
|
|
|
|
|
(search-forward "\n\n")
|
|
|
|
|
(setq end (point))
|
|
|
|
|
(goto-char beg)
|
|
|
|
|
(setq done (re-search-forward search-regexp end t))))))
|
|
|
|
|
(if done (setq found i)))
|
|
|
|
|
(setq n (if forward (1- n) (1+ n)))))
|
|
|
|
|
(if found
|
|
|
|
|
(rmail-summary-goto-msg found)
|
|
|
|
|
(error "No %s message with same subject"
|
|
|
|
|
(if forward "following" "previous")))))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-previous-same-subject (n)
|
|
|
|
|
"Go to the previous message in the summary having the same subject.
|
|
|
|
|
With prefix argument N, do this N times.
|
|
|
|
|
If N is negative, go forwards instead."
|
|
|
|
|
(interactive "p")
|
|
|
|
|
(rmail-summary-next-same-subject (- n)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
;; Delete and undelete summary commands.
|
|
|
|
|
|
1997-04-16 00:56:40 +00:00
|
|
|
|
(defun rmail-summary-delete-forward (&optional count)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
"Delete this message and move to next nondeleted one.
|
|
|
|
|
Deleted messages stay in the file until the \\[rmail-expunge] command is given.
|
1997-04-16 00:56:40 +00:00
|
|
|
|
A prefix argument serves as a repeat count;
|
|
|
|
|
a negative argument means to delete and move backward."
|
|
|
|
|
(interactive "p")
|
1997-05-19 01:05:13 +00:00
|
|
|
|
(unless (numberp count) (setq count 1))
|
1997-04-16 00:56:40 +00:00
|
|
|
|
(let (end del-msg
|
|
|
|
|
(backward (< count 0)))
|
|
|
|
|
(while (/= count 0)
|
|
|
|
|
(rmail-summary-goto-msg)
|
|
|
|
|
(with-current-buffer rmail-buffer
|
|
|
|
|
(rmail-delete-message)
|
|
|
|
|
(setq del-msg rmail-current-message))
|
1993-12-30 07:38:11 +00:00
|
|
|
|
(rmail-summary-mark-deleted del-msg)
|
|
|
|
|
(while (and (not (if backward (bobp) (eobp)))
|
1994-01-08 13:57:29 +00:00
|
|
|
|
(save-excursion (beginning-of-line)
|
1994-09-27 05:37:06 +00:00
|
|
|
|
(looking-at " *[0-9]+D")))
|
1994-10-15 22:24:10 +00:00
|
|
|
|
(forward-line (if backward -1 1)))
|
|
|
|
|
;; It looks ugly to move to the empty line at end of buffer.
|
|
|
|
|
(and (eobp) (not backward)
|
1997-04-16 00:56:40 +00:00
|
|
|
|
(forward-line -1))
|
|
|
|
|
(setq count
|
|
|
|
|
(if (> count 0) (1- count) (1+ count))))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1997-04-16 00:56:40 +00:00
|
|
|
|
(defun rmail-summary-delete-backward (&optional count)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
"Delete this message and move to previous nondeleted one.
|
1997-04-16 00:56:40 +00:00
|
|
|
|
Deleted messages stay in the file until the \\[rmail-expunge] command is given.
|
|
|
|
|
A prefix argument serves as a repeat count;
|
|
|
|
|
a negative argument means to delete and move forward."
|
|
|
|
|
(interactive "p")
|
|
|
|
|
(rmail-summary-delete-forward (- count)))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-mark-deleted (&optional n undel)
|
1996-01-24 23:30:25 +00:00
|
|
|
|
;; Since third arg is t, this only alters the summary, not the Rmail buf.
|
1993-05-25 21:20:08 +00:00
|
|
|
|
(and n (rmail-summary-goto-msg n t t))
|
|
|
|
|
(or (eobp)
|
1995-01-20 02:50:27 +00:00
|
|
|
|
(not (overlay-get rmail-summary-overlay 'face))
|
1993-05-25 21:20:08 +00:00
|
|
|
|
(let ((buffer-read-only nil))
|
|
|
|
|
(skip-chars-forward " ")
|
|
|
|
|
(skip-chars-forward "[0-9]")
|
|
|
|
|
(if undel
|
|
|
|
|
(if (looking-at "D")
|
|
|
|
|
(progn (delete-char 1) (insert " ")))
|
|
|
|
|
(delete-char 1)
|
|
|
|
|
(insert "D"))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(beginning-of-line))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-mark-undeleted (n)
|
|
|
|
|
(rmail-summary-mark-deleted n t))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-deleted-p (&optional n)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(and n (rmail-summary-goto-msg n nil t))
|
|
|
|
|
(skip-chars-forward " ")
|
|
|
|
|
(skip-chars-forward "[0-9]")
|
|
|
|
|
(looking-at "D")))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-undelete (&optional arg)
|
|
|
|
|
"Undelete current message.
|
|
|
|
|
Optional prefix ARG means undelete ARG previous messages."
|
|
|
|
|
(interactive "p")
|
|
|
|
|
(if (/= arg 1)
|
|
|
|
|
(rmail-summary-undelete-many arg)
|
1994-01-26 18:58:37 +00:00
|
|
|
|
(let ((buffer-read-only nil)
|
|
|
|
|
(opoint (point)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(end-of-line)
|
|
|
|
|
(cond ((re-search-backward "\\(^ *[0-9]*\\)\\(D\\)" nil t)
|
|
|
|
|
(replace-match "\\1 ")
|
|
|
|
|
(rmail-summary-goto-msg)
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(if rmail-enable-mime
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(pop-to-buffer rmail-buffer))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(and (rmail-message-deleted-p rmail-current-message)
|
|
|
|
|
(rmail-undelete-previous-message))
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(if rmail-enable-mime
|
|
|
|
|
(pop-to-buffer rmail-view-buffer))
|
1994-01-26 18:58:37 +00:00
|
|
|
|
(pop-to-buffer rmail-summary-buffer))
|
|
|
|
|
(t (goto-char opoint))))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-undelete-many (&optional n)
|
|
|
|
|
"Undelete all deleted msgs, optional prefix arg N means undelete N prev msgs."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(let* ((init-msg (if n rmail-current-message rmail-total-messages))
|
|
|
|
|
(rmail-current-message init-msg)
|
|
|
|
|
(n (or n rmail-total-messages))
|
|
|
|
|
(msgs-undeled 0))
|
|
|
|
|
(while (and (> rmail-current-message 0)
|
|
|
|
|
(< msgs-undeled n))
|
|
|
|
|
(if (rmail-message-deleted-p rmail-current-message)
|
|
|
|
|
(progn (rmail-set-attribute "deleted" nil)
|
|
|
|
|
(setq msgs-undeled (1+ msgs-undeled))))
|
|
|
|
|
(setq rmail-current-message (1- rmail-current-message)))
|
|
|
|
|
(set-buffer rmail-summary-buffer)
|
|
|
|
|
(setq rmail-current-message init-msg msgs-undeled 0)
|
|
|
|
|
(while (and (> rmail-current-message 0)
|
|
|
|
|
(< msgs-undeled n))
|
|
|
|
|
(if (rmail-summary-deleted-p rmail-current-message)
|
|
|
|
|
(progn (rmail-summary-mark-undeleted rmail-current-message)
|
|
|
|
|
(setq msgs-undeled (1+ msgs-undeled))))
|
|
|
|
|
(setq rmail-current-message (1- rmail-current-message))))
|
|
|
|
|
(rmail-summary-goto-msg)))
|
|
|
|
|
|
1990-11-30 22:29:57 +00:00
|
|
|
|
;; Rmail Summary mode is suitable only for specially formatted data.
|
|
|
|
|
(put 'rmail-summary-mode 'mode-class 'special)
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-mode ()
|
1993-03-09 08:08:52 +00:00
|
|
|
|
"Rmail Summary Mode is invoked from Rmail Mode by using \\<rmail-mode-map>\\[rmail-summary].
|
|
|
|
|
As commands are issued in the summary buffer, they are applied to the
|
|
|
|
|
corresponding mail messages in the rmail buffer.
|
|
|
|
|
|
|
|
|
|
All normal editing commands are turned off.
|
1993-11-23 07:11:22 +00:00
|
|
|
|
Instead, nearly all the Rmail mode commands are available,
|
|
|
|
|
though many of them move only among the messages in the summary.
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
1993-11-23 07:11:22 +00:00
|
|
|
|
These additional commands exist:
|
|
|
|
|
|
|
|
|
|
\\[rmail-summary-undelete-many] Undelete all or prefix arg deleted messages.
|
|
|
|
|
\\[rmail-summary-wipe] Delete the summary and go to the Rmail buffer.
|
|
|
|
|
|
|
|
|
|
Commands for sorting the summary:
|
|
|
|
|
|
|
|
|
|
\\[rmail-summary-sort-by-date] Sort by date.
|
|
|
|
|
\\[rmail-summary-sort-by-subject] Sort by subject.
|
|
|
|
|
\\[rmail-summary-sort-by-author] Sort by author.
|
|
|
|
|
\\[rmail-summary-sort-by-recipient] Sort by recipient.
|
|
|
|
|
\\[rmail-summary-sort-by-correspondent] Sort by correspondent.
|
1994-04-07 03:28:44 +00:00
|
|
|
|
\\[rmail-summary-sort-by-lines] Sort by lines.
|
2001-05-07 10:05:41 +00:00
|
|
|
|
\\[rmail-summary-sort-by-labels] Sort by labels."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive)
|
|
|
|
|
(kill-all-local-variables)
|
|
|
|
|
(setq major-mode 'rmail-summary-mode)
|
|
|
|
|
(setq mode-name "RMAIL Summary")
|
|
|
|
|
(setq truncate-lines t)
|
|
|
|
|
(setq buffer-read-only t)
|
|
|
|
|
(set-syntax-table text-mode-syntax-table)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(make-local-variable 'rmail-buffer)
|
1997-02-26 13:05:13 +00:00
|
|
|
|
(make-local-variable 'rmail-view-buffer)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(make-local-variable 'rmail-total-messages)
|
|
|
|
|
(make-local-variable 'rmail-current-message)
|
|
|
|
|
(setq rmail-current-message nil)
|
|
|
|
|
(make-local-variable 'rmail-summary-redo)
|
|
|
|
|
(setq rmail-summary-redo nil)
|
|
|
|
|
(make-local-variable 'revert-buffer-function)
|
1994-10-12 09:07:32 +00:00
|
|
|
|
(make-local-variable 'font-lock-defaults)
|
|
|
|
|
(setq font-lock-defaults '(rmail-summary-font-lock-keywords t))
|
1994-04-07 07:09:16 +00:00
|
|
|
|
(rmail-summary-enable)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(run-hooks 'rmail-summary-mode-hook))
|
|
|
|
|
|
1994-04-07 07:09:16 +00:00
|
|
|
|
;; Summary features need to be disabled during edit mode.
|
|
|
|
|
(defun rmail-summary-disable ()
|
1994-04-07 07:26:49 +00:00
|
|
|
|
(use-local-map text-mode-map)
|
1996-01-25 10:21:05 +00:00
|
|
|
|
(remove-hook 'post-command-hook 'rmail-summary-rmail-update t)
|
1994-04-07 07:26:49 +00:00
|
|
|
|
(setq revert-buffer-function nil))
|
1994-04-07 07:09:16 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-enable ()
|
1994-04-07 07:26:49 +00:00
|
|
|
|
(use-local-map rmail-summary-mode-map)
|
1996-01-25 10:21:05 +00:00
|
|
|
|
(add-hook 'post-command-hook 'rmail-summary-rmail-update nil t)
|
1994-04-07 07:26:49 +00:00
|
|
|
|
(setq revert-buffer-function 'rmail-update-summary))
|
1994-04-07 07:09:16 +00:00
|
|
|
|
|
1996-09-19 03:22:51 +00:00
|
|
|
|
(defvar rmail-summary-put-back-unseen nil
|
|
|
|
|
"Used for communicating between calls to `rmail-summary-rmail-update'.
|
|
|
|
|
If it moves to a message within an Incremental Search, and removes
|
|
|
|
|
the `unseen' attribute from that message, it sets this flag
|
|
|
|
|
so that if the next motion between messages is in the same Incremental
|
|
|
|
|
Search, the `unseen' attribute is restored.")
|
|
|
|
|
|
1993-03-13 21:52:43 +00:00
|
|
|
|
;; Show in Rmail the message described by the summary line that point is on,
|
|
|
|
|
;; but only if the Rmail buffer is already visible.
|
1993-03-09 08:08:52 +00:00
|
|
|
|
;; This is a post-command-hook in summary buffers.
|
|
|
|
|
(defun rmail-summary-rmail-update ()
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(let (buffer-read-only)
|
|
|
|
|
(save-excursion
|
|
|
|
|
;; If at end of buffer, pretend we are on the last text line.
|
|
|
|
|
(if (eobp)
|
|
|
|
|
(forward-line -1))
|
|
|
|
|
(beginning-of-line)
|
|
|
|
|
(skip-chars-forward " ")
|
|
|
|
|
(let ((msg-num (string-to-int (buffer-substring
|
|
|
|
|
(point)
|
|
|
|
|
(progn (skip-chars-forward "0-9")
|
|
|
|
|
(point))))))
|
1996-09-19 03:22:51 +00:00
|
|
|
|
;; Always leave `unseen' removed
|
|
|
|
|
;; if we get out of isearch mode.
|
|
|
|
|
;; Don't let a subsequent isearch restore that `unseen'.
|
|
|
|
|
(if (not isearch-mode)
|
|
|
|
|
(setq rmail-summary-put-back-unseen nil))
|
|
|
|
|
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(or (eq rmail-current-message msg-num)
|
1997-10-16 18:42:17 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-view-buffer t))
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(owin (selected-window)))
|
1996-09-19 03:22:51 +00:00
|
|
|
|
(if isearch-mode
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
;; If we first saw the previous message in this search,
|
|
|
|
|
;; and we have gone to a different message while searching,
|
|
|
|
|
;; put back `unseen' on the former one.
|
1998-06-04 06:47:29 +00:00
|
|
|
|
(if rmail-summary-put-back-unseen
|
1998-06-22 18:23:14 +00:00
|
|
|
|
(rmail-set-attribute "unseen" t
|
|
|
|
|
rmail-current-message))
|
1996-09-19 03:22:51 +00:00
|
|
|
|
;; Arrange to do that later, for the new current message,
|
|
|
|
|
;; if it still has `unseen'.
|
|
|
|
|
(setq rmail-summary-put-back-unseen
|
|
|
|
|
(rmail-message-labels-p msg-num ", ?\\(unseen\\),")))
|
|
|
|
|
(setq rmail-summary-put-back-unseen nil))
|
|
|
|
|
|
|
|
|
|
;; Go to the desired message.
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(setq rmail-current-message msg-num)
|
1996-09-19 03:22:51 +00:00
|
|
|
|
|
|
|
|
|
;; Update the summary to show the message has been seen.
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(if (= (following-char) ?-)
|
|
|
|
|
(progn
|
|
|
|
|
(delete-char 1)
|
|
|
|
|
(insert " ")))
|
1996-09-19 03:22:51 +00:00
|
|
|
|
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(if window
|
|
|
|
|
;; Using save-window-excursion would cause the new value
|
1993-06-03 21:02:10 +00:00
|
|
|
|
;; of point to get lost.
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(progn
|
|
|
|
|
(select-window window)
|
1994-10-11 04:43:01 +00:00
|
|
|
|
(rmail-show-message msg-num t))
|
1994-04-19 03:41:23 +00:00
|
|
|
|
(select-window owin))
|
1994-08-26 06:55:43 +00:00
|
|
|
|
(if (buffer-name rmail-buffer)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
1995-01-20 02:50:27 +00:00
|
|
|
|
(rmail-show-message msg-num t))))))
|
|
|
|
|
(rmail-summary-update-highlight nil)))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defvar rmail-summary-mode-map nil)
|
|
|
|
|
|
|
|
|
|
(if rmail-summary-mode-map
|
|
|
|
|
nil
|
|
|
|
|
(setq rmail-summary-mode-map (make-keymap))
|
|
|
|
|
(suppress-keymap rmail-summary-mode-map)
|
1997-08-04 01:42:50 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [mouse-2] 'rmail-summary-mouse-goto-message)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "a" 'rmail-summary-add-label)
|
1996-06-22 16:55:35 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "b" 'rmail-summary-bury)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "c" 'rmail-summary-continue)
|
|
|
|
|
(define-key rmail-summary-mode-map "d" 'rmail-summary-delete-forward)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-d" 'rmail-summary-delete-backward)
|
|
|
|
|
(define-key rmail-summary-mode-map "e" 'rmail-summary-edit-current-message)
|
|
|
|
|
(define-key rmail-summary-mode-map "f" 'rmail-summary-forward)
|
|
|
|
|
(define-key rmail-summary-mode-map "g" 'rmail-summary-get-new-mail)
|
|
|
|
|
(define-key rmail-summary-mode-map "h" 'rmail-summary)
|
|
|
|
|
(define-key rmail-summary-mode-map "i" 'rmail-summary-input)
|
|
|
|
|
(define-key rmail-summary-mode-map "j" 'rmail-summary-goto-msg)
|
1999-12-12 12:25:47 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "\C-m" 'rmail-summary-goto-msg)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "k" 'rmail-summary-kill-label)
|
|
|
|
|
(define-key rmail-summary-mode-map "l" 'rmail-summary-by-labels)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-h" 'rmail-summary)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-l" 'rmail-summary-by-labels)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-r" 'rmail-summary-by-recipients)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-s" 'rmail-summary-by-regexp)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-t" 'rmail-summary-by-topic)
|
|
|
|
|
(define-key rmail-summary-mode-map "m" 'rmail-summary-mail)
|
|
|
|
|
(define-key rmail-summary-mode-map "\M-m" 'rmail-summary-retry-failure)
|
|
|
|
|
(define-key rmail-summary-mode-map "n" 'rmail-summary-next-msg)
|
|
|
|
|
(define-key rmail-summary-mode-map "\en" 'rmail-summary-next-all)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-n" 'rmail-summary-next-labeled-message)
|
|
|
|
|
(define-key rmail-summary-mode-map "o" 'rmail-summary-output-to-rmail-file)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-o" 'rmail-summary-output)
|
|
|
|
|
(define-key rmail-summary-mode-map "p" 'rmail-summary-previous-msg)
|
|
|
|
|
(define-key rmail-summary-mode-map "\ep" 'rmail-summary-previous-all)
|
|
|
|
|
(define-key rmail-summary-mode-map "\e\C-p" 'rmail-summary-previous-labeled-message)
|
|
|
|
|
(define-key rmail-summary-mode-map "q" 'rmail-summary-quit)
|
1998-05-23 20:10:11 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "Q" 'rmail-summary-wipe)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "r" 'rmail-summary-reply)
|
|
|
|
|
(define-key rmail-summary-mode-map "s" 'rmail-summary-expunge-and-save)
|
|
|
|
|
(define-key rmail-summary-mode-map "\es" 'rmail-summary-search)
|
|
|
|
|
(define-key rmail-summary-mode-map "t" 'rmail-summary-toggle-header)
|
|
|
|
|
(define-key rmail-summary-mode-map "u" 'rmail-summary-undelete)
|
|
|
|
|
(define-key rmail-summary-mode-map "\M-u" 'rmail-summary-undelete-many)
|
|
|
|
|
(define-key rmail-summary-mode-map "x" 'rmail-summary-expunge)
|
1998-05-23 20:10:11 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "w" 'rmail-summary-output-body)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "." 'rmail-summary-beginning-of-message)
|
|
|
|
|
(define-key rmail-summary-mode-map "<" 'rmail-summary-first-message)
|
|
|
|
|
(define-key rmail-summary-mode-map ">" 'rmail-summary-last-message)
|
|
|
|
|
(define-key rmail-summary-mode-map " " 'rmail-summary-scroll-msg-up)
|
|
|
|
|
(define-key rmail-summary-mode-map "\177" 'rmail-summary-scroll-msg-down)
|
|
|
|
|
(define-key rmail-summary-mode-map "?" 'describe-mode)
|
1995-02-05 02:46:34 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-n" 'rmail-summary-next-same-subject)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-p" 'rmail-summary-previous-same-subject)
|
1993-06-22 05:55:59 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-d"
|
|
|
|
|
'rmail-summary-sort-by-date)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-s"
|
|
|
|
|
'rmail-summary-sort-by-subject)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-a"
|
|
|
|
|
'rmail-summary-sort-by-author)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-r"
|
|
|
|
|
'rmail-summary-sort-by-recipient)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-c"
|
|
|
|
|
'rmail-summary-sort-by-correspondent)
|
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-l"
|
|
|
|
|
'rmail-summary-sort-by-lines)
|
1994-04-07 03:28:44 +00:00
|
|
|
|
(define-key rmail-summary-mode-map "\C-c\C-s\C-k"
|
2001-05-07 10:05:41 +00:00
|
|
|
|
'rmail-summary-sort-by-labels)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
)
|
|
|
|
|
|
1993-06-22 02:25:05 +00:00
|
|
|
|
;;; Menu bar bindings.
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar] (make-sparse-keymap))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify]
|
|
|
|
|
(cons "Classify" (make-sparse-keymap "Classify")))
|
|
|
|
|
|
1994-08-26 06:55:43 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output-menu]
|
|
|
|
|
'("Output (Rmail Menu)..." . rmail-summary-output-menu))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify input-menu]
|
1995-05-30 23:05:08 +00:00
|
|
|
|
'("Input Rmail File (menu)..." . rmail-input-menu))
|
1994-08-26 06:55:43 +00:00
|
|
|
|
|
1994-09-19 05:03:02 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify input-menu]
|
|
|
|
|
'(nil))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output-menu]
|
|
|
|
|
'(nil))
|
|
|
|
|
|
1998-05-23 20:10:11 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output-body]
|
|
|
|
|
'("Output (body)..." . rmail-summary-output-body))
|
|
|
|
|
|
1993-06-22 02:25:05 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output-inbox]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("Output (inbox)..." . rmail-summary-output))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("Output (Rmail)..." . rmail-summary-output-to-rmail-file))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify kill-label]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("Kill Label..." . rmail-summary-kill-label))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify add-label]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("Add Label..." . rmail-summary-add-label))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary]
|
|
|
|
|
(cons "Summary" (make-sparse-keymap "Summary")))
|
|
|
|
|
|
1996-06-25 18:15:12 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary senders]
|
|
|
|
|
'("By Senders..." . rmail-summary-by-senders))
|
|
|
|
|
|
1993-06-22 02:25:05 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary labels]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("By Labels..." . rmail-summary-by-labels))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary recipients]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("By Recipients..." . rmail-summary-by-recipients))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary topic]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("By Topic..." . rmail-summary-by-topic))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary regexp]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("By Regexp..." . rmail-summary-by-regexp))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar summary all]
|
|
|
|
|
'("All" . rmail-summary))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail]
|
|
|
|
|
(cons "Mail" (make-sparse-keymap "Mail")))
|
|
|
|
|
|
1994-08-02 01:57:49 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail rmail-summary-get-new-mail]
|
1994-07-31 05:32:03 +00:00
|
|
|
|
'("Get New Mail" . rmail-summary-get-new-mail))
|
|
|
|
|
|
1994-08-02 02:22:45 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail lambda]
|
1994-07-31 05:32:03 +00:00
|
|
|
|
'("----"))
|
1994-07-29 21:26:38 +00:00
|
|
|
|
|
1993-06-22 02:25:05 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail continue]
|
|
|
|
|
'("Continue" . rmail-summary-continue))
|
|
|
|
|
|
1994-07-31 05:32:03 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail resend]
|
1994-10-11 17:07:27 +00:00
|
|
|
|
'("Re-send..." . rmail-summary-resend))
|
1994-07-31 05:32:03 +00:00
|
|
|
|
|
1993-06-22 02:25:05 +00:00
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail forward]
|
|
|
|
|
'("Forward" . rmail-summary-forward))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail retry]
|
|
|
|
|
'("Retry" . rmail-summary-retry-failure))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail reply]
|
|
|
|
|
'("Reply" . rmail-summary-reply))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar mail mail]
|
|
|
|
|
'("Mail" . rmail-summary-mail))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar delete]
|
|
|
|
|
(cons "Delete" (make-sparse-keymap "Delete")))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar delete expunge/save]
|
|
|
|
|
'("Expunge/Save" . rmail-summary-expunge-and-save))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar delete expunge]
|
|
|
|
|
'("Expunge" . rmail-summary-expunge))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar delete undelete]
|
|
|
|
|
'("Undelete" . rmail-summary-undelete))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar delete delete]
|
|
|
|
|
'("Delete" . rmail-summary-delete-forward))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move]
|
|
|
|
|
(cons "Move" (make-sparse-keymap "Move")))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move search-back]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("Search Back..." . rmail-summary-search-backward))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move search]
|
1994-08-02 02:26:35 +00:00
|
|
|
|
'("Search..." . rmail-summary-search))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move previous]
|
|
|
|
|
'("Previous Nondeleted" . rmail-summary-previous-msg))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move next]
|
|
|
|
|
'("Next Nondeleted" . rmail-summary-next-msg))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move last]
|
|
|
|
|
'("Last" . rmail-summary-last-message))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move first]
|
|
|
|
|
'("First" . rmail-summary-first-message))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move previous]
|
|
|
|
|
'("Previous" . rmail-summary-previous-all))
|
|
|
|
|
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar move next]
|
|
|
|
|
'("Next" . rmail-summary-next-all))
|
|
|
|
|
|
1994-03-19 05:32:26 +00:00
|
|
|
|
(defvar rmail-summary-overlay nil)
|
1995-11-11 20:37:24 +00:00
|
|
|
|
(put 'rmail-summary-overlay 'permanent-local t)
|
1994-03-19 05:32:26 +00:00
|
|
|
|
|
1997-08-04 01:42:50 +00:00
|
|
|
|
(defun rmail-summary-mouse-goto-message (event)
|
|
|
|
|
"Select the message whose summary line you click on."
|
|
|
|
|
(interactive "@e")
|
|
|
|
|
(goto-char (posn-point (event-end event)))
|
|
|
|
|
(rmail-summary-goto-msg))
|
1996-01-24 23:30:25 +00:00
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-goto-msg (&optional n nowarn skip-rmail)
|
1997-08-04 01:42:50 +00:00
|
|
|
|
"Go to message N in the summary buffer and the Rmail buffer.
|
|
|
|
|
If N is nil, use the message corresponding to point in the summary
|
|
|
|
|
and move to that message in the Rmail buffer.
|
|
|
|
|
|
|
|
|
|
If NOWARN, don't say anything if N is out of range.
|
|
|
|
|
If SKIP-RMAIL, don't do anything to the Rmail buffer."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive "P")
|
|
|
|
|
(if (consp n) (setq n (prefix-numeric-value n)))
|
|
|
|
|
(if (eobp) (forward-line -1))
|
|
|
|
|
(beginning-of-line)
|
1994-10-06 07:05:09 +00:00
|
|
|
|
(let* ((obuf (current-buffer))
|
|
|
|
|
(buf rmail-buffer)
|
|
|
|
|
(cur (point))
|
|
|
|
|
message-not-found
|
|
|
|
|
(curmsg (string-to-int
|
|
|
|
|
(buffer-substring (point)
|
2001-10-05 09:35:36 +00:00
|
|
|
|
(min (point-max) (+ 6 (point))))))
|
1994-10-06 07:05:09 +00:00
|
|
|
|
(total (save-excursion (set-buffer buf) rmail-total-messages)))
|
1994-03-19 05:32:26 +00:00
|
|
|
|
;; If message number N was specified, find that message's line
|
|
|
|
|
;; or set message-not-found.
|
|
|
|
|
;; If N wasn't specified or that message can't be found.
|
|
|
|
|
;; set N by default.
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(if (not n)
|
|
|
|
|
(setq n curmsg)
|
|
|
|
|
(if (< n 1)
|
|
|
|
|
(progn (message "No preceding message")
|
|
|
|
|
(setq n 1)))
|
2003-11-01 16:38:55 +00:00
|
|
|
|
(if (and (> n total)
|
|
|
|
|
(> total 0))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(progn (message "No following message")
|
|
|
|
|
(goto-char (point-max))
|
1996-01-24 23:30:25 +00:00
|
|
|
|
(rmail-summary-goto-msg nil nowarn skip-rmail)))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(goto-char (point-min))
|
2001-10-05 09:35:36 +00:00
|
|
|
|
(if (not (re-search-forward (format "^%5d[^0-9]" n) nil t))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(progn (or nowarn (message "Message %d not found" n))
|
|
|
|
|
(setq n curmsg)
|
1994-03-19 05:32:26 +00:00
|
|
|
|
(setq message-not-found t)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(goto-char cur))))
|
|
|
|
|
(beginning-of-line)
|
|
|
|
|
(skip-chars-forward " ")
|
|
|
|
|
(skip-chars-forward "0-9")
|
|
|
|
|
(save-excursion (if (= (following-char) ?-)
|
|
|
|
|
(let ((buffer-read-only nil))
|
|
|
|
|
(delete-char 1)
|
|
|
|
|
(insert " "))))
|
1995-01-20 02:50:27 +00:00
|
|
|
|
(rmail-summary-update-highlight message-not-found)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(beginning-of-line)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(if skip-rmail
|
|
|
|
|
nil
|
1993-12-23 03:25:40 +00:00
|
|
|
|
(let ((selwin (selected-window)))
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(progn (pop-to-buffer buf)
|
|
|
|
|
(rmail-show-message n))
|
1994-09-13 04:14:00 +00:00
|
|
|
|
(select-window selwin)
|
|
|
|
|
;; The actions above can alter the current buffer. Preserve it.
|
|
|
|
|
(set-buffer obuf))))))
|
1995-01-20 02:50:27 +00:00
|
|
|
|
|
|
|
|
|
;; Update the highlighted line in an rmail summary buffer.
|
|
|
|
|
;; That should be current. We highlight the line point is on.
|
|
|
|
|
;; If NOT-FOUND is non-nil, we turn off highlighting.
|
|
|
|
|
(defun rmail-summary-update-highlight (not-found)
|
|
|
|
|
;; Make sure we have an overlay to use.
|
|
|
|
|
(or rmail-summary-overlay
|
|
|
|
|
(progn
|
|
|
|
|
(make-local-variable 'rmail-summary-overlay)
|
|
|
|
|
(setq rmail-summary-overlay (make-overlay (point) (point)))))
|
|
|
|
|
;; If this message is in the summary, use the overlay to highlight it.
|
|
|
|
|
;; Otherwise, don't highlight anything.
|
|
|
|
|
(if not-found
|
|
|
|
|
(overlay-put rmail-summary-overlay 'face nil)
|
|
|
|
|
(move-overlay rmail-summary-overlay
|
|
|
|
|
(save-excursion (beginning-of-line)
|
|
|
|
|
(skip-chars-forward " ")
|
|
|
|
|
(point))
|
|
|
|
|
(save-excursion (end-of-line) (point)))
|
|
|
|
|
(overlay-put rmail-summary-overlay 'face 'highlight)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-summary-scroll-msg-up (&optional dist)
|
1994-11-20 15:01:14 +00:00
|
|
|
|
"Scroll the Rmail window forward.
|
|
|
|
|
If the Rmail window is displaying the end of a message,
|
|
|
|
|
advance to the next message."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive "P")
|
1994-11-20 15:01:14 +00:00
|
|
|
|
(if (eq dist '-)
|
|
|
|
|
(rmail-summary-scroll-msg-down nil)
|
1997-02-26 13:05:13 +00:00
|
|
|
|
(let ((rmail-buffer-window (get-buffer-window rmail-view-buffer)))
|
1994-11-20 15:01:14 +00:00
|
|
|
|
(if rmail-buffer-window
|
|
|
|
|
(if (let ((rmail-summary-window (selected-window)))
|
|
|
|
|
(select-window rmail-buffer-window)
|
|
|
|
|
(prog1
|
|
|
|
|
;; Is EOB visible in the buffer?
|
|
|
|
|
(save-excursion
|
|
|
|
|
(let ((ht (window-height (selected-window))))
|
|
|
|
|
(move-to-window-line (- ht 2))
|
|
|
|
|
(end-of-line)
|
|
|
|
|
(eobp)))
|
|
|
|
|
(select-window rmail-summary-window)))
|
1996-04-04 17:01:45 +00:00
|
|
|
|
(if (not rmail-summary-scroll-between-messages)
|
|
|
|
|
(error "End of buffer")
|
|
|
|
|
(rmail-summary-next-msg (or dist 1)))
|
1997-02-26 13:05:13 +00:00
|
|
|
|
(let ((other-window-scroll-buffer rmail-view-buffer))
|
1994-11-20 15:01:14 +00:00
|
|
|
|
(scroll-other-window dist)))
|
1996-12-14 02:11:32 +00:00
|
|
|
|
;; If it isn't visible at all, show the beginning.
|
|
|
|
|
(rmail-summary-beginning-of-message)))))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-scroll-msg-down (&optional dist)
|
1994-11-20 15:01:14 +00:00
|
|
|
|
"Scroll the Rmail window backward.
|
1996-12-14 02:11:32 +00:00
|
|
|
|
If the Rmail window is now displaying the beginning of a message,
|
|
|
|
|
move to the previous message."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive "P")
|
1994-11-20 15:01:14 +00:00
|
|
|
|
(if (eq dist '-)
|
|
|
|
|
(rmail-summary-scroll-msg-up nil)
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(let ((rmail-buffer-window (get-buffer-window rmail-view-buffer)))
|
1994-11-20 15:01:14 +00:00
|
|
|
|
(if rmail-buffer-window
|
|
|
|
|
(if (let ((rmail-summary-window (selected-window)))
|
|
|
|
|
(select-window rmail-buffer-window)
|
|
|
|
|
(prog1
|
|
|
|
|
;; Is BOB visible in the buffer?
|
|
|
|
|
(save-excursion
|
|
|
|
|
(move-to-window-line 0)
|
|
|
|
|
(beginning-of-line)
|
|
|
|
|
(bobp))
|
|
|
|
|
(select-window rmail-summary-window)))
|
1996-04-04 17:01:45 +00:00
|
|
|
|
(if (not rmail-summary-scroll-between-messages)
|
|
|
|
|
(error "Beginning of buffer")
|
|
|
|
|
(rmail-summary-previous-msg (or dist 1)))
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(let ((other-window-scroll-buffer rmail-view-buffer))
|
1994-11-20 15:01:14 +00:00
|
|
|
|
(scroll-other-window-down dist)))
|
1996-12-14 02:11:32 +00:00
|
|
|
|
;; If it isn't visible at all, show the beginning.
|
|
|
|
|
(rmail-summary-beginning-of-message)))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-beginning-of-message ()
|
|
|
|
|
"Show current message from the beginning."
|
|
|
|
|
(interactive)
|
1996-12-14 02:11:32 +00:00
|
|
|
|
(if (and (one-window-p) (not pop-up-frames))
|
|
|
|
|
;; If there is just one window, put the summary on the top.
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(let ((buffer rmail-view-buffer))
|
1996-12-14 02:11:32 +00:00
|
|
|
|
(split-window (selected-window) rmail-summary-window-size)
|
|
|
|
|
(select-window (frame-first-window))
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(pop-to-buffer rmail-view-buffer)
|
1996-12-14 02:11:32 +00:00
|
|
|
|
;; If pop-to-buffer did not use that window, delete that
|
|
|
|
|
;; window. (This can happen if it uses another frame.)
|
|
|
|
|
(or (eq buffer (window-buffer (next-window (frame-first-window))))
|
|
|
|
|
(delete-other-windows)))
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(pop-to-buffer rmail-view-buffer))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(beginning-of-buffer)
|
|
|
|
|
(pop-to-buffer rmail-summary-buffer))
|
1990-11-30 22:29:57 +00:00
|
|
|
|
|
1996-06-22 16:55:35 +00:00
|
|
|
|
(defun rmail-summary-bury ()
|
|
|
|
|
"Bury the Rmail buffer and the Rmail summary buffer."
|
|
|
|
|
(interactive)
|
|
|
|
|
(let ((buffer-to-bury (current-buffer)))
|
|
|
|
|
(let (window)
|
|
|
|
|
(while (setq window (get-buffer-window rmail-buffer))
|
|
|
|
|
(set-window-buffer window (other-buffer rmail-buffer)))
|
|
|
|
|
(bury-buffer rmail-buffer))
|
|
|
|
|
(switch-to-buffer (other-buffer buffer-to-bury))
|
|
|
|
|
(bury-buffer buffer-to-bury)))
|
|
|
|
|
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(defun rmail-summary-quit ()
|
1993-03-09 08:08:52 +00:00
|
|
|
|
"Quit out of Rmail and Rmail summary."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(rmail-summary-wipe)
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(rmail-quit))
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-wipe ()
|
|
|
|
|
"Kill and wipe away Rmail summary, remaining within Rmail."
|
1990-11-30 22:29:57 +00:00
|
|
|
|
(interactive)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(save-excursion (set-buffer rmail-buffer) (setq rmail-summary-buffer nil))
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(let ((local-rmail-buffer rmail-view-buffer))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(kill-buffer (current-buffer))
|
|
|
|
|
;; Delete window if not only one.
|
|
|
|
|
(if (not (eq (selected-window) (next-window nil 'no-minibuf)))
|
|
|
|
|
(delete-window))
|
1993-11-23 07:11:22 +00:00
|
|
|
|
;; Switch windows to the rmail buffer, or switch to it in this window.
|
|
|
|
|
(pop-to-buffer local-rmail-buffer)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-expunge ()
|
|
|
|
|
"Actually erase all deleted messages and recompute summary headers."
|
|
|
|
|
(interactive)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
2000-12-12 14:52:36 +00:00
|
|
|
|
(when (rmail-expunge-confirmed)
|
2000-12-04 16:40:31 +00:00
|
|
|
|
(rmail-only-expunge)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(rmail-update-summary))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-expunge-and-save ()
|
|
|
|
|
"Expunge and save RMAIL file."
|
|
|
|
|
(interactive)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
2000-12-12 14:52:36 +00:00
|
|
|
|
(when (rmail-expunge-confirmed)
|
2000-12-04 16:40:31 +00:00
|
|
|
|
(rmail-only-expunge)))
|
1993-06-04 02:24:45 +00:00
|
|
|
|
(rmail-update-summary)
|
|
|
|
|
(save-excursion
|
1993-06-03 21:02:10 +00:00
|
|
|
|
(set-buffer rmail-buffer)
|
1994-02-09 04:26:28 +00:00
|
|
|
|
(save-buffer))
|
|
|
|
|
(set-buffer-modified-p nil))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
1997-08-27 16:18:29 +00:00
|
|
|
|
(defun rmail-summary-get-new-mail (&optional file-name)
|
|
|
|
|
"Get new mail and recompute summary headers.
|
|
|
|
|
|
|
|
|
|
Optionally you can specify the file to get new mail from. In this case,
|
|
|
|
|
the file of new mail is not changed or deleted. Noninteractively, you can
|
|
|
|
|
pass the inbox file name as an argument. Interactively, a prefix
|
|
|
|
|
argument says to read a file name and use that file as the inbox."
|
|
|
|
|
(interactive
|
|
|
|
|
(list (if current-prefix-arg
|
|
|
|
|
(read-file-name "Get new mail from file: "))))
|
1993-06-04 02:24:45 +00:00
|
|
|
|
(let (msg)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
1997-08-27 16:18:29 +00:00
|
|
|
|
(rmail-get-new-mail file-name)
|
1993-06-04 02:24:45 +00:00
|
|
|
|
;; Get the proper new message number.
|
|
|
|
|
(setq msg rmail-current-message))
|
|
|
|
|
;; Make sure that message is displayed.
|
1995-11-30 00:30:38 +00:00
|
|
|
|
(or (zerop msg)
|
|
|
|
|
(rmail-summary-goto-msg msg))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-input (filename)
|
|
|
|
|
"Run Rmail on file FILENAME."
|
|
|
|
|
(interactive "FRun rmail on RMAIL file: ")
|
1993-06-04 02:24:45 +00:00
|
|
|
|
;; We switch windows here, then display the other Rmail file there.
|
|
|
|
|
(pop-to-buffer rmail-buffer)
|
|
|
|
|
(rmail filename))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-first-message ()
|
|
|
|
|
"Show first message in Rmail file from summary buffer."
|
|
|
|
|
(interactive)
|
|
|
|
|
(beginning-of-buffer))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-last-message ()
|
|
|
|
|
"Show last message in Rmail file from summary buffer."
|
|
|
|
|
(interactive)
|
|
|
|
|
(end-of-buffer)
|
|
|
|
|
(forward-line -1))
|
|
|
|
|
|
|
|
|
|
(defvar rmail-summary-edit-map nil)
|
|
|
|
|
(if rmail-summary-edit-map
|
|
|
|
|
nil
|
|
|
|
|
(setq rmail-summary-edit-map
|
1993-11-12 22:16:44 +00:00
|
|
|
|
(nconc (make-sparse-keymap) text-mode-map))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(define-key rmail-summary-edit-map "\C-c\C-c" 'rmail-cease-edit)
|
|
|
|
|
(define-key rmail-summary-edit-map "\C-c\C-]" 'rmail-abort-edit))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-edit-current-message ()
|
|
|
|
|
"Edit the contents of this message."
|
|
|
|
|
(interactive)
|
|
|
|
|
(pop-to-buffer rmail-buffer)
|
|
|
|
|
(rmail-edit-current-message)
|
|
|
|
|
(use-local-map rmail-summary-edit-map))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-cease-edit ()
|
|
|
|
|
"Finish editing message, then go back to Rmail summary buffer."
|
|
|
|
|
(interactive)
|
|
|
|
|
(rmail-cease-edit)
|
|
|
|
|
(pop-to-buffer rmail-summary-buffer))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-abort-edit ()
|
|
|
|
|
"Abort edit of current message; restore original contents.
|
|
|
|
|
Go back to summary buffer."
|
|
|
|
|
(interactive)
|
|
|
|
|
(rmail-abort-edit)
|
|
|
|
|
(pop-to-buffer rmail-summary-buffer))
|
|
|
|
|
|
1993-06-22 02:25:05 +00:00
|
|
|
|
(defun rmail-summary-search-backward (regexp &optional n)
|
|
|
|
|
"Show message containing next match for REGEXP.
|
|
|
|
|
Prefix argument gives repeat count; negative argument means search
|
|
|
|
|
backwards (through earlier messages).
|
|
|
|
|
Interactively, empty argument means use same regexp used last time."
|
|
|
|
|
(interactive
|
|
|
|
|
(let* ((reversep (>= (prefix-numeric-value current-prefix-arg) 0))
|
|
|
|
|
(prompt
|
|
|
|
|
(concat (if reversep "Reverse " "") "Rmail search (regexp): "))
|
|
|
|
|
regexp)
|
|
|
|
|
(if rmail-search-last-regexp
|
|
|
|
|
(setq prompt (concat prompt
|
|
|
|
|
"(default "
|
|
|
|
|
rmail-search-last-regexp
|
|
|
|
|
") ")))
|
|
|
|
|
(setq regexp (read-string prompt))
|
|
|
|
|
(cond ((not (equal regexp ""))
|
|
|
|
|
(setq rmail-search-last-regexp regexp))
|
|
|
|
|
((not rmail-search-last-regexp)
|
|
|
|
|
(error "No previous Rmail search string")))
|
|
|
|
|
(list rmail-search-last-regexp
|
|
|
|
|
(prefix-numeric-value current-prefix-arg))))
|
|
|
|
|
;; Don't use save-excursion because that prevents point from moving
|
|
|
|
|
;; properly in the summary buffer.
|
|
|
|
|
(let ((buffer (current-buffer)))
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(progn
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-search regexp (- n)))
|
|
|
|
|
(set-buffer buffer))))
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-search (regexp &optional n)
|
|
|
|
|
"Show message containing next match for REGEXP.
|
|
|
|
|
Prefix argument gives repeat count; negative argument means search
|
|
|
|
|
backwards (through earlier messages).
|
|
|
|
|
Interactively, empty argument means use same regexp used last time."
|
|
|
|
|
(interactive
|
|
|
|
|
(let* ((reversep (< (prefix-numeric-value current-prefix-arg) 0))
|
|
|
|
|
(prompt
|
|
|
|
|
(concat (if reversep "Reverse " "") "Rmail search (regexp): "))
|
|
|
|
|
regexp)
|
|
|
|
|
(if rmail-search-last-regexp
|
|
|
|
|
(setq prompt (concat prompt
|
|
|
|
|
"(default "
|
|
|
|
|
rmail-search-last-regexp
|
|
|
|
|
") ")))
|
|
|
|
|
(setq regexp (read-string prompt))
|
|
|
|
|
(cond ((not (equal regexp ""))
|
|
|
|
|
(setq rmail-search-last-regexp regexp))
|
|
|
|
|
((not rmail-search-last-regexp)
|
|
|
|
|
(error "No previous Rmail search string")))
|
|
|
|
|
(list rmail-search-last-regexp
|
|
|
|
|
(prefix-numeric-value current-prefix-arg))))
|
1993-06-22 02:25:05 +00:00
|
|
|
|
;; Don't use save-excursion because that prevents point from moving
|
|
|
|
|
;; properly in the summary buffer.
|
|
|
|
|
(let ((buffer (current-buffer)))
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(progn
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-search regexp n))
|
|
|
|
|
(set-buffer buffer))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-toggle-header ()
|
|
|
|
|
"Show original message header if pruned header currently shown, or vice versa."
|
|
|
|
|
(interactive)
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(save-window-excursion
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(set-buffer rmail-buffer)
|
1995-03-31 19:36:02 +00:00
|
|
|
|
(rmail-toggle-header))
|
|
|
|
|
;; Inside save-excursion, some changes to point in the RMAIL buffer are lost.
|
|
|
|
|
;; Set point to point-min in the RMAIL buffer, if it is visible.
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-view-buffer)))
|
1995-03-31 19:36:02 +00:00
|
|
|
|
(if window
|
|
|
|
|
;; Using save-window-excursion would lose the new value of point.
|
|
|
|
|
(let ((owin (selected-window)))
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(progn
|
|
|
|
|
(select-window window)
|
|
|
|
|
(goto-char (point-min)))
|
|
|
|
|
(select-window owin))))))
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-add-label (label)
|
|
|
|
|
"Add LABEL to labels associated with current Rmail message.
|
|
|
|
|
Completion is performed over known labels when reading."
|
1993-06-03 21:02:10 +00:00
|
|
|
|
(interactive (list (save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-read-label "Add label"))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-add-label label)))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-kill-label (label)
|
|
|
|
|
"Remove LABEL from labels associated with current Rmail message.
|
|
|
|
|
Completion is performed over known labels when reading."
|
1993-06-03 21:02:10 +00:00
|
|
|
|
(interactive (list (save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-read-label "Kill label"))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(rmail-set-label label nil)))
|
|
|
|
|
|
|
|
|
|
;;;; *** Rmail Summary Mailing Commands ***
|
|
|
|
|
|
2001-03-12 15:58:05 +00:00
|
|
|
|
(defun rmail-summary-override-mail-send-and-exit ()
|
2003-02-06 22:02:35 +00:00
|
|
|
|
"Replace bindings to `mail-send-and-exit' with `rmail-summary-send-and-exit'."
|
2001-03-12 15:58:05 +00:00
|
|
|
|
(use-local-map (copy-keymap (current-local-map)))
|
|
|
|
|
(dolist (key (where-is-internal 'mail-send-and-exit))
|
|
|
|
|
(define-key (current-local-map) key 'rmail-summary-send-and-exit)))
|
|
|
|
|
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(defun rmail-summary-mail ()
|
|
|
|
|
"Send mail in another window.
|
|
|
|
|
While composing the message, use \\[mail-yank-original] to yank the
|
|
|
|
|
original message into it."
|
|
|
|
|
(interactive)
|
1995-02-19 19:11:03 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-buffer)))
|
|
|
|
|
(if window
|
|
|
|
|
(select-window window)
|
|
|
|
|
(set-buffer rmail-buffer)))
|
|
|
|
|
(rmail-start-mail nil nil nil nil nil (current-buffer))
|
2001-03-12 15:58:05 +00:00
|
|
|
|
(rmail-summary-override-mail-send-and-exit))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-continue ()
|
|
|
|
|
"Continue composing outgoing message previously being composed."
|
|
|
|
|
(interactive)
|
1995-02-19 19:11:03 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-buffer)))
|
|
|
|
|
(if window
|
|
|
|
|
(select-window window)
|
|
|
|
|
(set-buffer rmail-buffer)))
|
1994-01-31 07:05:45 +00:00
|
|
|
|
(rmail-start-mail t))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-reply (just-sender)
|
|
|
|
|
"Reply to the current message.
|
|
|
|
|
Normally include CC: to all other recipients of original message;
|
1994-01-31 07:05:45 +00:00
|
|
|
|
prefix argument means ignore them. While composing the reply,
|
|
|
|
|
use \\[mail-yank-original] to yank the original message into it."
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(interactive "P")
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-view-buffer)))
|
1995-02-19 19:11:03 +00:00
|
|
|
|
(if window
|
|
|
|
|
(select-window window)
|
2001-05-08 11:18:48 +00:00
|
|
|
|
(set-buffer rmail-view-buffer)))
|
1994-01-31 07:05:45 +00:00
|
|
|
|
(rmail-reply just-sender)
|
2001-03-12 15:58:05 +00:00
|
|
|
|
(rmail-summary-override-mail-send-and-exit))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-retry-failure ()
|
|
|
|
|
"Edit a mail message which is based on the contents of the current message.
|
|
|
|
|
For a message rejected by the mail system, extract the interesting headers and
|
|
|
|
|
the body of the original message; otherwise copy the current message."
|
|
|
|
|
(interactive)
|
1995-02-19 19:11:03 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-buffer)))
|
|
|
|
|
(if window
|
|
|
|
|
(select-window window)
|
|
|
|
|
(set-buffer rmail-buffer)))
|
1994-01-31 07:05:45 +00:00
|
|
|
|
(rmail-retry-failure)
|
2001-03-12 15:58:05 +00:00
|
|
|
|
(rmail-summary-override-mail-send-and-exit))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-send-and-exit ()
|
|
|
|
|
"Send mail reply and return to summary buffer."
|
|
|
|
|
(interactive)
|
|
|
|
|
(mail-send-and-exit t))
|
|
|
|
|
|
1993-11-14 05:50:47 +00:00
|
|
|
|
(defun rmail-summary-forward (resend)
|
|
|
|
|
"Forward the current message to another user.
|
|
|
|
|
With prefix argument, \"resend\" the message instead of forwarding it;
|
|
|
|
|
see the documentation of `rmail-resend'."
|
|
|
|
|
(interactive "P")
|
1993-03-09 08:08:52 +00:00
|
|
|
|
(save-excursion
|
1995-02-19 19:11:03 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-buffer)))
|
|
|
|
|
(if window
|
|
|
|
|
(select-window window)
|
|
|
|
|
(set-buffer rmail-buffer)))
|
1993-11-14 05:50:47 +00:00
|
|
|
|
(rmail-forward resend)
|
2001-03-12 15:58:05 +00:00
|
|
|
|
(rmail-summary-override-mail-send-and-exit)))
|
1994-10-11 17:07:27 +00:00
|
|
|
|
|
|
|
|
|
(defun rmail-summary-resend ()
|
2003-02-06 22:02:35 +00:00
|
|
|
|
"Resend current message using `rmail-resend'."
|
1994-10-11 17:07:27 +00:00
|
|
|
|
(interactive)
|
|
|
|
|
(save-excursion
|
1995-02-19 19:11:03 +00:00
|
|
|
|
(let ((window (get-buffer-window rmail-buffer)))
|
|
|
|
|
(if window
|
|
|
|
|
(select-window window)
|
|
|
|
|
(set-buffer rmail-buffer)))
|
1994-10-11 17:07:27 +00:00
|
|
|
|
(call-interactively 'rmail-resend)))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
|
|
|
|
;; Summary output commands.
|
|
|
|
|
|
1999-06-13 02:33:49 +00:00
|
|
|
|
(defun rmail-summary-output-to-rmail-file (&optional file-name n)
|
1993-03-09 08:08:52 +00:00
|
|
|
|
"Append the current message to an Rmail file named FILE-NAME.
|
|
|
|
|
If the file does not exist, ask if it should be created.
|
|
|
|
|
If file is being visited, the message is appended to the Emacs
|
1998-09-10 15:35:34 +00:00
|
|
|
|
buffer visiting that file.
|
|
|
|
|
|
|
|
|
|
A prefix argument N says to output N consecutive messages
|
|
|
|
|
starting with the current one. Deleted messages are skipped and don't count."
|
1999-01-04 01:36:00 +00:00
|
|
|
|
(interactive
|
|
|
|
|
(progn (require 'rmailout)
|
|
|
|
|
(list (rmail-output-read-rmail-file-name)
|
|
|
|
|
(prefix-numeric-value current-prefix-arg))))
|
1999-06-15 05:35:56 +00:00
|
|
|
|
(let ((i 0) prev-msg)
|
2003-02-04 13:24:35 +00:00
|
|
|
|
(while
|
1999-06-15 05:35:56 +00:00
|
|
|
|
(and (< i n)
|
|
|
|
|
(progn (rmail-summary-goto-msg)
|
|
|
|
|
(not (eq prev-msg
|
|
|
|
|
(setq prev-msg
|
2003-02-04 13:24:35 +00:00
|
|
|
|
(with-current-buffer rmail-buffer
|
1999-06-15 05:35:56 +00:00
|
|
|
|
rmail-current-message))))))
|
1999-01-04 01:36:00 +00:00
|
|
|
|
(setq i (1+ i))
|
|
|
|
|
(with-current-buffer rmail-buffer
|
|
|
|
|
(let ((rmail-delete-after-output nil))
|
|
|
|
|
(rmail-output-to-rmail-file file-name 1)))
|
|
|
|
|
(if rmail-delete-after-output
|
|
|
|
|
(rmail-summary-delete-forward nil)
|
|
|
|
|
(if (< i n)
|
|
|
|
|
(rmail-summary-next-msg 1))))))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-output (&optional file-name n)
|
|
|
|
|
"Append this message to Unix mail file named FILE-NAME.
|
|
|
|
|
|
|
|
|
|
A prefix argument N says to output N consecutive messages
|
|
|
|
|
starting with the current one. Deleted messages are skipped and don't count."
|
|
|
|
|
(interactive
|
|
|
|
|
(progn (require 'rmailout)
|
|
|
|
|
(list (rmail-output-read-file-name)
|
|
|
|
|
(prefix-numeric-value current-prefix-arg))))
|
2002-02-23 17:14:34 +00:00
|
|
|
|
(let ((i 0) prev-msg)
|
|
|
|
|
(while
|
|
|
|
|
(and (< i n)
|
|
|
|
|
(progn (rmail-summary-goto-msg)
|
|
|
|
|
(not (eq prev-msg
|
|
|
|
|
(setq prev-msg
|
|
|
|
|
(with-current-buffer rmail-buffer
|
|
|
|
|
rmail-current-message))))))
|
1999-01-04 01:36:00 +00:00
|
|
|
|
(setq i (1+ i))
|
|
|
|
|
(with-current-buffer rmail-buffer
|
|
|
|
|
(let ((rmail-delete-after-output nil))
|
|
|
|
|
(rmail-output file-name 1)))
|
|
|
|
|
(if rmail-delete-after-output
|
|
|
|
|
(rmail-summary-delete-forward nil)
|
|
|
|
|
(if (< i n)
|
|
|
|
|
(rmail-summary-next-msg 1))))))
|
1993-03-09 08:08:52 +00:00
|
|
|
|
|
1994-08-26 06:55:43 +00:00
|
|
|
|
(defun rmail-summary-output-menu ()
|
|
|
|
|
"Output current message to another Rmail file, chosen with a menu.
|
|
|
|
|
Also set the default for subsequent \\[rmail-output-to-rmail-file] commands.
|
|
|
|
|
The variables `rmail-secondary-file-directory' and
|
|
|
|
|
`rmail-secondary-file-regexp' control which files are offered in the menu."
|
|
|
|
|
(interactive)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(let ((rmail-delete-after-output nil))
|
|
|
|
|
(call-interactively 'rmail-output-menu)))
|
|
|
|
|
(if rmail-delete-after-output
|
|
|
|
|
(rmail-summary-delete-forward nil)))
|
|
|
|
|
|
1994-09-19 05:03:02 +00:00
|
|
|
|
(defun rmail-summary-construct-io-menu ()
|
|
|
|
|
(let ((files (rmail-find-all-files rmail-secondary-file-directory)))
|
1995-09-06 15:16:39 +00:00
|
|
|
|
(if files
|
1994-09-19 05:03:02 +00:00
|
|
|
|
(progn
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify input-menu]
|
2003-02-04 13:24:35 +00:00
|
|
|
|
(cons "Input Rmail File"
|
|
|
|
|
(rmail-list-to-menu "Input Rmail File"
|
1995-09-06 15:16:39 +00:00
|
|
|
|
files
|
1994-09-19 05:03:02 +00:00
|
|
|
|
'rmail-summary-input)))
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output-menu]
|
2003-02-04 13:24:35 +00:00
|
|
|
|
(cons "Output Rmail File"
|
|
|
|
|
(rmail-list-to-menu "Output Rmail File"
|
1995-09-06 15:16:39 +00:00
|
|
|
|
files
|
|
|
|
|
'rmail-summary-output-to-rmail-file))))
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify input-menu]
|
|
|
|
|
'("Input Rmail File" . rmail-disable-menu))
|
|
|
|
|
(define-key rmail-summary-mode-map [menu-bar classify output-menu]
|
|
|
|
|
'("Output Rmail File" . rmail-disable-menu)))))
|
1994-09-19 05:03:02 +00:00
|
|
|
|
|
1998-05-23 20:10:11 +00:00
|
|
|
|
(defun rmail-summary-output-body (&optional file-name)
|
|
|
|
|
"Write this message body to the file FILE-NAME.
|
|
|
|
|
FILE-NAME defaults, interactively, from the Subject field of the message."
|
|
|
|
|
(interactive)
|
|
|
|
|
(save-excursion
|
|
|
|
|
(set-buffer rmail-buffer)
|
|
|
|
|
(let ((rmail-delete-after-output nil))
|
|
|
|
|
(if file-name
|
|
|
|
|
(rmail-output-body-to-file file-name)
|
|
|
|
|
(call-interactively 'rmail-output-body-to-file))))
|
|
|
|
|
(if rmail-delete-after-output
|
|
|
|
|
(rmail-summary-delete-forward nil)))
|
1993-06-22 05:55:59 +00:00
|
|
|
|
|
|
|
|
|
;; Sorting messages in Rmail Summary buffer.
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-sort-by-date (reverse)
|
|
|
|
|
"Sort messages of current Rmail summary by date.
|
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(rmail-sort-from-summary (function rmail-sort-by-date) reverse))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-sort-by-subject (reverse)
|
|
|
|
|
"Sort messages of current Rmail summary by subject.
|
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(rmail-sort-from-summary (function rmail-sort-by-subject) reverse))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-sort-by-author (reverse)
|
|
|
|
|
"Sort messages of current Rmail summary by author.
|
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(rmail-sort-from-summary (function rmail-sort-by-author) reverse))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-sort-by-recipient (reverse)
|
|
|
|
|
"Sort messages of current Rmail summary by recipient.
|
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(rmail-sort-from-summary (function rmail-sort-by-recipient) reverse))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-sort-by-correspondent (reverse)
|
|
|
|
|
"Sort messages of current Rmail summary by other correspondent.
|
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(rmail-sort-from-summary (function rmail-sort-by-correspondent) reverse))
|
|
|
|
|
|
|
|
|
|
(defun rmail-summary-sort-by-lines (reverse)
|
|
|
|
|
"Sort messages of current Rmail summary by lines of the message.
|
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order."
|
|
|
|
|
(interactive "P")
|
|
|
|
|
(rmail-sort-from-summary (function rmail-sort-by-lines) reverse))
|
|
|
|
|
|
2001-05-07 10:05:41 +00:00
|
|
|
|
(defun rmail-summary-sort-by-labels (reverse labels)
|
|
|
|
|
"Sort messages of current Rmail summary by labels.
|
1994-04-07 03:28:44 +00:00
|
|
|
|
If prefix argument REVERSE is non-nil, sort them in reverse order.
|
|
|
|
|
KEYWORDS is a comma-separated list of labels."
|
|
|
|
|
(interactive "P\nsSort by labels: ")
|
|
|
|
|
(rmail-sort-from-summary
|
|
|
|
|
(function (lambda (reverse)
|
2001-05-07 10:05:41 +00:00
|
|
|
|
(rmail-sort-by-labels reverse labels)))
|
1994-04-07 03:28:44 +00:00
|
|
|
|
reverse))
|
|
|
|
|
|
1993-06-22 05:55:59 +00:00
|
|
|
|
(defun rmail-sort-from-summary (sortfun reverse)
|
|
|
|
|
"Sort Rmail messages from Summary buffer and update it after sorting."
|
|
|
|
|
(require 'rmailsort)
|
1994-03-30 02:21:19 +00:00
|
|
|
|
(let ((selwin (selected-window)))
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(progn (pop-to-buffer rmail-buffer)
|
|
|
|
|
(funcall sortfun reverse))
|
|
|
|
|
(select-window selwin))))
|
1992-05-30 21:11:25 +00:00
|
|
|
|
|
2000-05-25 18:20:20 +00:00
|
|
|
|
(provide 'rmailsum)
|
|
|
|
|
|
2003-09-01 15:45:59 +00:00
|
|
|
|
;;; arch-tag: 556079ee-75c1-47f5-9884-2e0a0bc6c5a1
|
1992-05-30 21:11:25 +00:00
|
|
|
|
;;; rmailsum.el ends here
|