* eshell/esh-util.el (eshell-under-xemacs-p): Remove.
[emacs.git] / lisp / mh-e / mh-e.el
blob694541107018734298297fb1a4f683fd56591cde
1 ;;; mh-e.el --- GNU Emacs interface to the MH mail system
3 ;; Copyright (C) 1985, 1986, 1987, 1988,
4 ;; 1990, 1992, 1993, 1994, 1995, 1997, 1999,
5 ;; 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
7 ;; Author: Bill Wohler <wohler@newt.com>
8 ;; Maintainer: Bill Wohler <wohler@newt.com>
9 ;; Version: 8.0.3+cvs
10 ;; Keywords: mail
12 ;; This file is part of GNU Emacs.
14 ;; GNU Emacs is free software; you can redistribute it and/or modify
15 ;; it under the terms of the GNU General Public License as published by
16 ;; the Free Software Foundation; either version 3, or (at your option)
17 ;; any later version.
19 ;; GNU Emacs is distributed in the hope that it will be useful,
20 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 ;; GNU General Public License for more details.
24 ;; You should have received a copy of the GNU General Public License
25 ;; along with GNU Emacs; see the file COPYING. If not, write to the
26 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
27 ;; Boston, MA 02110-1301, USA.
29 ;;; Commentary:
31 ;; MH-E is an Emacs interface to the MH mail system.
33 ;; MH-E is supported by GNU Emacs 21 and 22, as well as XEmacs 21
34 ;; (except for versions 21.5.9-21.5.16). It is compatible with MH
35 ;; versions 6.8.4 and higher, all versions of nmh, and GNU mailutils
36 ;; 0.4 and higher.
38 ;; MH (Message Handler) is a powerful mail reader. See
39 ;; http://rand-mh.sourceforge.net/.
41 ;; N.B. MH must have been compiled with the MHE compiler flag or several
42 ;; features necessary for MH-E will be missing from MH commands, specifically
43 ;; the -build switch to repl and forw.
45 ;; How to use:
46 ;; M-x mh-rmail to read mail. Type C-h m there for a list of commands.
47 ;; C-u M-x mh-rmail to visit any folder.
48 ;; M-x mh-smail to send mail. From within the mail reader, "s" works, too.
50 ;; Your .emacs might benefit from these bindings:
51 ;; (global-set-key "\C-cr" 'mh-rmail)
52 ;; (global-set-key "\C-xm" 'mh-smail)
53 ;; (global-set-key "\C-x4m" 'mh-smail-other-window)
55 ;; If Emacs can't find mh-rmail or mh-smail, add the following to ~/.emacs:
56 ;; (require 'mh-autoloads)
58 ;; If you want to customize MH-E before explicitly loading it, add this:
59 ;; (require 'mh-cus-load)
61 ;; Mailing Lists:
62 ;; mh-e-users@lists.sourceforge.net
63 ;; mh-e-announce@lists.sourceforge.net
64 ;; mh-e-devel@lists.sourceforge.net
66 ;; Subscribe by sending a "subscribe" message to
67 ;; <list>-request@lists.sourceforge.net, or by using the web interface at
68 ;; https://sourceforge.net/mail/?group_id=13357
70 ;; Bug Reports:
71 ;; https://sourceforge.net/tracker/?group_id=13357&atid=113357
72 ;; Include the output of M-x mh-version in the bug report unless
73 ;; you're 110% sure we won't ask for it.
75 ;; Feature Requests:
76 ;; https://sourceforge.net/tracker/?group_id=13357&atid=363357
78 ;; Support:
79 ;; https://sourceforge.net/tracker/?group_id=13357&atid=213357
81 ;;; Change Log:
83 ;; Original version for Gosling emacs by Brian Reid, Stanford, 1982.
84 ;; Modified by James Larus, BBN, July 1984 and UCB, 1984 & 1985.
85 ;; Rewritten for GNU Emacs, James Larus, 1985.
86 ;; Modified by Stephen Gildea, 1988.
87 ;; Maintenance picked up by Bill Wohler and the
88 ;; SourceForge Crew <http://mh-e.sourceforge.net/>, 2001.
90 ;;; Code:
92 ;; Provide functions to the rest of MH-E. However, mh-e.el must not
93 ;; use any definitions in files that require mh-e from mh-loaddefs,
94 ;; for if it does it will introduce a require loop.
95 (require 'mh-loaddefs)
97 (mh-require-cl)
99 (require 'mh-buffers)
100 (require 'mh-compat)
102 (mh-do-in-xemacs
103 (require 'mh-xemacs))
105 (mh-font-lock-add-keywords
106 'emacs-lisp-mode
107 (eval-when-compile
108 `((,(concat "(\\("
109 ;; Function declarations (use font-lock-function-name-face).
110 "\\(def\\(un\\|macro\\)-mh\\)\\|"
111 ;; Variable declarations (use font-lock-variable-name-face).
112 "\\(def\\(custom\\|face\\)-mh\\)\\|"
113 ;; Group declarations (use font-lock-type-face).
114 "\\(defgroup-mh\\)"
115 "\\)\\>"
116 ;; Any whitespace and defined object.
117 "[ \t'\(]*"
118 "\\(setf[ \t]+\\sw+)\\|\\sw+\\)?")
119 (1 font-lock-keyword-face)
120 (7 (cond ((match-beginning 2) font-lock-function-name-face)
121 ((match-beginning 4) font-lock-variable-name-face)
122 (t font-lock-type-face))
123 nil t)))))
127 ;;; Global Variables
129 ;; Try to keep variables local to a single file. Provide accessors if
130 ;; variables are shared. Use this section as a last resort.
132 (defconst mh-version "8.0.3+cvs" "Version number of MH-E.")
134 ;; Variants
136 (defvar mh-sys-path
137 '("/usr/local/nmh/bin" ; nmh default
138 "/usr/local/bin/mh/"
139 "/usr/local/mh/"
140 "/usr/bin/mh/" ; Ultrix 4.2, Linux
141 "/usr/new/mh/" ; Ultrix < 4.2
142 "/usr/contrib/mh/bin/" ; BSDI
143 "/usr/pkg/bin/" ; NetBSD
144 "/usr/local/bin/"
145 "/usr/local/bin/mu-mh/" ; GNU mailutils - default
146 "/usr/bin/mu-mh/") ; GNU mailutils - packaged
147 "List of directories to search for variants of the MH variant.
148 The list `exec-path' is searched in addition to this list.
149 There's no need for users to modify this list. Instead add extra
150 directories to the customizable variable `mh-path'.")
152 (defvar mh-variants nil
153 "List describing known MH variants.
154 Do not access this variable directly as it may not have yet been initialized.
155 Use the function `mh-variants' instead.")
157 (defvar mh-variant-in-use nil
158 "The MH variant currently in use; a string with variant and version number.
159 This differs from `mh-variant' when the latter is set to
160 \"autodetect\".")
162 (defvar mh-progs nil
163 "Directory containing MH commands, such as inc, repl, and rmm.")
165 ;;;###autoload
166 (put 'mh-progs 'risky-local-variable t)
168 (defvar mh-lib nil
169 "Directory containing the MH library.
170 This directory contains, among other things, the components file.")
172 ;;;###autoload
173 (put 'mh-lib 'risky-local-variable t)
175 (defvar mh-lib-progs nil
176 "Directory containing MH helper programs.
177 This directory contains, among other things, the mhl program.")
179 ;;;###autoload
180 (put 'mh-lib-progs 'risky-local-variable t)
182 ;; Profile Components
184 (defvar mh-draft-folder nil
185 "Cached value of the \"Draft-Folder:\" MH profile component.
186 Name of folder containing draft messages.
187 Do not use a draft folder if nil.")
189 (defvar mh-inbox nil
190 "Cached value of the \"Inbox:\" MH profile component.
191 Set to \"+inbox\" if no such component.
192 Name of the Inbox folder.")
194 (defvar mh-user-path nil
195 "Cached value of the \"Path:\" MH profile component.
196 User's mail folder directory.")
198 ;; Maps declared here so that they can be used in docstrings.
200 (defvar mh-folder-mode-map (make-keymap)
201 "Keymap for MH-Folder mode.")
203 (defvar mh-folder-seq-tool-bar-map nil
204 "Keymap for MH-Folder tool bar.")
206 (defvar mh-folder-tool-bar-map nil
207 "Keymap for MH-Folder tool bar.")
209 (defvar mh-inc-spool-map (make-sparse-keymap)
210 "Keymap for MH-E's mh-inc-spool commands.")
212 (defvar mh-letter-mode-map (copy-keymap text-mode-map)
213 "Keymap for MH-Letter mode.")
215 (defvar mh-letter-tool-bar-map nil
216 "Keymap for MH-Letter tool bar.")
218 (defvar mh-search-mode-map (make-sparse-keymap)
219 "Keymap for MH-Search mode.")
221 (defvar mh-show-mode-map (make-sparse-keymap)
222 "Keymap MH-Show mode.")
224 (defvar mh-show-seq-tool-bar-map nil
225 "Keymap for MH-Show tool bar.")
227 (defvar mh-show-tool-bar-map nil
228 "Keymap for MH-Show tool bar.")
230 ;; MH-Folder Locals (alphabetical)
232 (defvar mh-arrow-marker nil
233 "Marker for arrow display in fringe.")
235 (defvar mh-colors-available-flag nil
236 "Non-nil means colors are available.")
238 (defvar mh-current-folder nil
239 "Name of current folder, a string.")
241 (defvar mh-delete-list nil
242 "List of message numbers to delete.
243 This variable can be used by
244 `mh-before-commands-processed-hook'.")
246 (defvar mh-folder-view-stack nil
247 "Stack of previous folder views.")
249 (defvar mh-index-data nil
250 "Info about index search results.")
252 (defvar mh-index-previous-search nil)
254 (defvar mh-index-msg-checksum-map nil)
256 (defvar mh-index-checksum-origin-map nil)
258 (defvar mh-index-sequence-search-flag nil)
260 (defvar mh-mode-line-annotation nil
261 "Message range displayed in buffer.")
263 (defvar mh-next-direction 'forward
264 "Direction to move to next message.")
266 (defvar mh-previous-window-config nil
267 "Window configuration before MH-E command.")
269 (defvar mh-refile-list nil
270 "List of folder names in `mh-seq-list'.
271 This variable can be used by
272 `mh-before-commands-processed-hook'.")
274 (defvar mh-seen-list nil
275 "List of displayed messages to be removed from the \"Unseen\" sequence.")
277 (defvar mh-seq-list nil
278 "Alist of this folder's sequences.
279 Elements have the form (SEQUENCE . MESSAGES).")
281 (defvar mh-sequence-notation-history nil
282 "Remember original notation that is overwritten by `mh-note-seq'.")
284 (defvar mh-show-buffer nil
285 "Buffer that displays message for this folder.")
287 (defvar mh-showing-mode nil
288 "If non-nil, show the message in a separate window.")
290 (defvar mh-view-ops nil
291 "Stack of operations that change the folder view.
292 These operations include narrowing or threading.")
294 ;; MH-Show Locals (alphabetical)
296 (defvar mh-globals-hash (make-hash-table)
297 "Keeps track of MIME data on a per buffer basis.")
299 (defvar mh-show-folder-buffer nil
300 "Keeps track of folder whose message is being displayed.")
302 ;; MH-Letter Locals
304 (defvar mh-folders-changed nil
305 "Lists which folders were affected by deletes and refiles.
306 This list will always include the current folder
307 `mh-current-folder'. This variable can be used by
308 `mh-after-commands-processed-hook'.")
310 (defvar mh-mail-header-separator "--------"
311 "*Line used by MH to separate headers from text in messages being composed.
313 This variable should not be used directly in programs. Programs
314 should use `mail-header-separator' instead.
315 `mail-header-separator' is initialized to
316 `mh-mail-header-separator' in `mh-letter-mode'; in other
317 contexts, you may have to perform this initialization yourself.
319 Do not make this a regular expression as it may be the argument
320 to `insert' and it is passed through `regexp-quote' before being
321 used by functions like `re-search-forward'.")
323 (defvar mh-sent-from-folder nil
324 "Folder of msg assoc with this letter.")
326 (defvar mh-sent-from-msg nil
327 "Number of msg assoc with this letter.")
329 ;; Sequences
331 (defvar mh-unseen-seq nil
332 "Cached value of the \"Unseen-Sequence:\" MH profile component.
333 Name of the Unseen sequence.")
335 (defvar mh-previous-seq nil
336 "Cached value of the \"Previous-Sequence:\" MH profile component.
337 Name of the Previous sequence.")
339 ;; Etc. (alphabetical)
341 (defvar mh-flists-present-flag nil
342 "Non-nil means that we have \"flists\".")
344 (defvar mh-index-data-file ".mhe_index"
345 "MH-E specific file where index seach info is stored.")
347 (defvar mh-letter-header-field-regexp "^\\([A-Za-z][A-Za-z0-9-]*\\):")
349 (defvar mh-page-to-next-msg-flag nil
350 "Non-nil means next SPC or whatever goes to next undeleted message.")
352 (defvar mh-pgp-support-flag (not (not (locate-library "mml2015")))
353 "Non-nil means PGP support is available.")
355 (defvar mh-signature-separator "-- \n"
356 "Text of a signature separator.
358 A signature separator is used to separate the body of a message
359 from the signature. This can be used by user agents such as MH-E
360 to render the signature differently or to suppress the inclusion
361 of the signature in a reply. Use `mh-signature-separator-regexp'
362 when searching for a separator.")
364 (defvar mh-signature-separator-regexp "^-- $"
365 "This regular expression matches the signature separator.
366 See `mh-signature-separator'.")
368 (defvar mh-thread-scan-line-map nil
369 "Map of message index to various parts of the scan line.")
370 (make-variable-buffer-local 'mh-thread-scan-line-map)
372 (defvar mh-thread-scan-line-map-stack nil
373 "Old map of message index to various parts of the scan line.
374 This is the original map that is stored when the folder is
375 narrowed.")
376 (make-variable-buffer-local 'mh-thread-scan-line-map-stack)
378 (defvar mh-x-mailer-string nil
379 "*String containing the contents of the X-Mailer header field.
380 If nil, this variable is initialized to show the version of MH-E,
381 Emacs, and MH the first time a message is composed.")
385 ;;; MH-E Entry Points
387 (eval-when-compile (require 'gnus))
389 (defmacro mh-macro-expansion-time-gnus-version ()
390 "Return Gnus version available at macro expansion time.
391 The macro evaluates the Gnus version at macro expansion time. If
392 MH-E was compiled then macro expansion happens at compile time."
393 gnus-version)
395 (defun mh-run-time-gnus-version ()
396 "Return Gnus version available at run time."
397 (require 'gnus)
398 gnus-version)
400 ;;;###autoload
401 (defun mh-version ()
402 "Display version information about MH-E and the MH mail handling system."
403 (interactive)
404 (set-buffer (get-buffer-create mh-info-buffer))
405 (erase-buffer)
406 ;; MH-E version.
407 (insert "MH-E " mh-version "\n\n")
408 ;; MH-E compilation details.
409 (insert "MH-E compilation details:\n")
410 (let* ((compiled-mhe (byte-code-function-p (symbol-function 'mh-version)))
411 (gnus-compiled-version (if compiled-mhe
412 (mh-macro-expansion-time-gnus-version)
413 "N/A")))
414 (insert " Byte compiled:\t\t" (if compiled-mhe "yes" "no") "\n"
415 " Gnus (compile-time):\t" gnus-compiled-version "\n"
416 " Gnus (run-time):\t" (mh-run-time-gnus-version) "\n\n"))
417 ;; Emacs version.
418 (insert (emacs-version) "\n\n")
419 ;; MH version.
420 (if mh-variant-in-use
421 (insert mh-variant-in-use "\n"
422 " mh-progs:\t" mh-progs "\n"
423 " mh-lib:\t" mh-lib "\n"
424 " mh-lib-progs:\t" mh-lib-progs "\n\n")
425 (insert "No MH variant detected\n"))
426 ;; Linux version.
427 (condition-case ()
428 (call-process "uname" nil t nil "-a")
429 (file-error))
430 (goto-char (point-min))
431 (display-buffer mh-info-buffer))
435 ;;; Support Routines
437 (defun mh-list-to-string (l)
438 "Flatten the list L and make every element of the new list into a string."
439 (nreverse (mh-list-to-string-1 l)))
441 (defun mh-list-to-string-1 (l)
442 "Flatten the list L and make every element of the new list into a string."
443 (let (new-list)
444 (dolist (element l)
445 (cond ((null element))
446 ((symbolp element)
447 (push (symbol-name element) new-list))
448 ((numberp element)
449 (push (int-to-string element) new-list))
450 ((equal element ""))
451 ((stringp element)
452 (push element new-list))
453 ((listp element)
454 (setq new-list (nconc (mh-list-to-string-1 element) new-list)))
456 (error "Bad element: %s" element))))
457 new-list))
461 ;;; MH-E Process Support
463 (defvar mh-index-max-cmdline-args 500
464 "Maximum number of command line args.")
466 (defun mh-xargs (cmd &rest args)
467 "Partial imitation of xargs.
468 The current buffer contains a list of strings, one on each line.
469 The function will execute CMD with ARGS and pass the first
470 `mh-index-max-cmdline-args' strings to it. This is repeated till
471 all the strings have been used."
472 (goto-char (point-min))
473 (let ((current-buffer (current-buffer)))
474 (with-temp-buffer
475 (let ((out (current-buffer)))
476 (set-buffer current-buffer)
477 (while (not (eobp))
478 (let ((arg-list (reverse args))
479 (count 0))
480 (while (and (not (eobp)) (< count mh-index-max-cmdline-args))
481 (push (buffer-substring-no-properties (point)
482 (mh-line-end-position))
483 arg-list)
484 (incf count)
485 (forward-line))
486 (apply #'call-process cmd nil (list out nil) nil
487 (nreverse arg-list))))
488 (erase-buffer)
489 (insert-buffer-substring out)))))
491 ;; XXX This should be applied anywhere MH-E calls out to /bin/sh.
492 (defun mh-quote-for-shell (string)
493 "Quote STRING for /bin/sh.
494 Adds double-quotes around entire string and quotes the characters
495 \\, `, and $ with a backslash."
496 (concat "\""
497 (loop for x across string
498 concat (format (if (memq x '(?\\ ?` ?$)) "\\%c" "%c") x))
499 "\""))
501 (defun mh-exec-cmd (command &rest args)
502 "Execute mh-command COMMAND with ARGS.
503 The side effects are what is desired. Any output is assumed to be
504 an error and is shown to the user. The output is not read or
505 parsed by MH-E."
506 (save-excursion
507 (set-buffer (get-buffer-create mh-log-buffer))
508 (let* ((initial-size (mh-truncate-log-buffer))
509 (start (point))
510 (args (mh-list-to-string args)))
511 (apply 'call-process (expand-file-name command mh-progs) nil t nil args)
512 (when (> (buffer-size) initial-size)
513 (save-excursion
514 (goto-char start)
515 (insert "Errors when executing: " command)
516 (loop for arg in args do (insert " " arg))
517 (insert "\n"))
518 (save-window-excursion
519 (switch-to-buffer-other-window mh-log-buffer)
520 (sit-for 5))))))
522 (defun mh-exec-cmd-error (env command &rest args)
523 "In environment ENV, execute mh-command COMMAND with ARGS.
524 ENV is nil or a string of space-separated \"var=value\" elements.
525 Signals an error if process does not complete successfully."
526 (save-excursion
527 (set-buffer (get-buffer-create mh-temp-buffer))
528 (erase-buffer)
529 (let ((process-environment process-environment))
530 ;; XXX: We should purge the list that split-string returns of empty
531 ;; strings. This can happen in XEmacs if leading or trailing spaces
532 ;; are present.
533 (dolist (elem (if (stringp env) (split-string env " ") ()))
534 (push elem process-environment))
535 (mh-handle-process-error
536 command (apply #'call-process (expand-file-name command mh-progs)
537 nil t nil (mh-list-to-string args))))))
539 (defun mh-exec-cmd-daemon (command filter &rest args)
540 "Execute MH command COMMAND in the background.
542 If FILTER is non-nil then it is used to process the output
543 otherwise the default filter `mh-process-daemon' is used. See
544 `set-process-filter' for more details of FILTER.
546 ARGS are passed to COMMAND as command line arguments."
547 (save-excursion
548 (set-buffer (get-buffer-create mh-log-buffer))
549 (mh-truncate-log-buffer))
550 (let* ((process-connection-type nil)
551 (process (apply 'start-process
552 command nil
553 (expand-file-name command mh-progs)
554 (mh-list-to-string args))))
555 (set-process-filter process (or filter 'mh-process-daemon))
556 process))
558 (defun mh-exec-cmd-env-daemon (env command filter &rest args)
559 "In ennvironment ENV, execute mh-command COMMAND in the background.
561 ENV is nil or a string of space-separated \"var=value\" elements.
562 Signals an error if process does not complete successfully.
564 If FILTER is non-nil then it is used to process the output
565 otherwise the default filter `mh-process-daemon' is used. See
566 `set-process-filter' for more details of FILTER.
568 ARGS are passed to COMMAND as command line arguments."
569 (let ((process-environment process-environment))
570 (dolist (elem (if (stringp env) (split-string env " ") ()))
571 (push elem process-environment))
572 (apply #'mh-exec-cmd-daemon command filter args)))
574 (defun mh-process-daemon (process output)
575 "PROCESS daemon that puts OUTPUT into a temporary buffer.
576 Any output from the process is displayed in an asynchronous
577 pop-up window."
578 (with-current-buffer (get-buffer-create mh-log-buffer)
579 (insert-before-markers output)
580 (display-buffer mh-log-buffer)))
582 (defun mh-exec-cmd-quiet (raise-error command &rest args)
583 "Signal RAISE-ERROR if COMMAND with ARGS fails.
584 Execute MH command COMMAND with ARGS. ARGS is a list of strings.
585 Return at start of mh-temp buffer, where output can be parsed and
586 used.
587 Returns value of `call-process', which is 0 for success, unless
588 RAISE-ERROR is non-nil, in which case an error is signaled if
589 `call-process' returns non-0."
590 (set-buffer (get-buffer-create mh-temp-buffer))
591 (erase-buffer)
592 (let ((value
593 (apply 'call-process
594 (expand-file-name command mh-progs) nil t nil
595 args)))
596 (goto-char (point-min))
597 (if raise-error
598 (mh-handle-process-error command value)
599 value)))
601 (defun mh-exec-cmd-output (command display &rest args)
602 "Execute MH command COMMAND with DISPLAY flag and ARGS.
603 Put the output into buffer after point.
604 Set mark after inserted text.
605 Output is expected to be shown to user, not parsed by MH-E."
606 (push-mark (point) t)
607 (apply 'call-process
608 (expand-file-name command mh-progs) nil t display
609 (mh-list-to-string args))
611 ;; The following is used instead of 'exchange-point-and-mark because the
612 ;; latter activates the current region (between point and mark), which
613 ;; turns on highlighting. So prior to this bug fix, doing "inc" would
614 ;; highlight a region containing the new messages, which is undesirable.
615 ;; The bug wasn't seen in emacs21 but still occurred in XEmacs21.4.
616 (mh-exchange-point-and-mark-preserving-active-mark))
618 ;; Shush compiler.
619 (defvar mark-active) ; XEmacs
621 (defun mh-exchange-point-and-mark-preserving-active-mark ()
622 "Put the mark where point is now, and point where the mark is now.
623 This command works even when the mark is not active, and
624 preserves whether the mark is active or not."
625 (interactive nil)
626 (let ((is-active (and (boundp 'mark-active) mark-active)))
627 (let ((omark (mark t)))
628 (if (null omark)
629 (error "No mark set in this buffer"))
630 (set-mark (point))
631 (goto-char omark)
632 (if (boundp 'mark-active)
633 (setq mark-active is-active))
634 nil)))
636 (defun mh-exec-lib-cmd-output (command &rest args)
637 "Execute MH library command COMMAND with ARGS.
638 Put the output into buffer after point.
639 Set mark after inserted text."
640 (apply 'mh-exec-cmd-output (expand-file-name command mh-lib-progs) nil args))
642 (defun mh-handle-process-error (command status)
643 "Raise error if COMMAND returned non-zero STATUS, otherwise return STATUS."
644 (if (equal status 0)
645 status
646 (goto-char (point-min))
647 (insert (if (integerp status)
648 (format "%s: exit code %d\n" command status)
649 (format "%s: %s\n" command status)))
650 (save-excursion
651 (let ((error-message (buffer-substring (point-min) (point-max))))
652 (set-buffer (get-buffer-create mh-log-buffer))
653 (mh-truncate-log-buffer)
654 (insert error-message)))
655 (error "%s failed, check buffer %s for error message"
656 command mh-log-buffer)))
660 ;;; MH-E Customization Support Routines
662 ;; Shush compiler (Emacs 21 and XEmacs).
663 (defvar customize-package-emacs-version-alist)
665 ;; Temporary function and data structure used customization.
666 ;; These will be unbound after the options are defined.
667 (defmacro mh-strip-package-version (args)
668 "Strip :package-version keyword and its value from ARGS.
669 In Emacs versions that support the :package-version keyword,
670 ARGS is returned unchanged."
671 `(if (boundp 'customize-package-emacs-version-alist)
672 ,args
673 (let (seen)
674 (loop for keyword in ,args
675 if (cond ((eq keyword ':package-version) (setq seen t) nil)
676 (seen (setq seen nil) nil)
677 (t t))
678 collect keyword))))
680 (defmacro defgroup-mh (symbol members doc &rest args)
681 "Declare SYMBOL as a customization group containing MEMBERS.
682 See documentation for `defgroup' for a description of the arguments
683 SYMBOL, MEMBERS, DOC and ARGS.
684 This macro is used by Emacs versions that lack the :package-version
685 keyword, introduced in Emacs 22."
686 (declare (doc-string 3))
687 `(defgroup ,symbol ,members ,doc ,@(mh-strip-package-version args)))
688 (put 'defgroup-mh 'lisp-indent-function 'defun)
690 (defmacro defcustom-mh (symbol value doc &rest args)
691 "Declare SYMBOL as a customizable variable that defaults to VALUE.
692 See documentation for `defcustom' for a description of the arguments
693 SYMBOL, VALUE, DOC and ARGS.
694 This macro is used by Emacs versions that lack the :package-version
695 keyword, introduced in Emacs 22."
696 (declare (doc-string 3))
697 `(defcustom ,symbol ,value ,doc ,@(mh-strip-package-version args)))
698 (put 'defcustom-mh 'lisp-indent-function 'defun)
700 (defmacro defface-mh (face spec doc &rest args)
701 "Declare FACE as a customizable face that defaults to SPEC.
702 See documentation for `defface' for a description of the arguments
703 FACE, SPEC, DOC and ARGS.
704 This macro is used by Emacs versions that lack the :package-version
705 keyword, introduced in Emacs 22."
706 (declare (doc-string 3))
707 `(defface ,face ,spec ,doc ,@(mh-strip-package-version args)))
708 (put 'defface-mh 'lisp-indent-function 'defun)
712 ;;; Variant Support
714 (defcustom-mh mh-path nil
715 "*Additional list of directories to search for MH.
716 See `mh-variant'."
717 :group 'mh-e
718 :type '(repeat (directory))
719 :package-version '(MH-E "8.0"))
721 (defun mh-variants ()
722 "Return a list of installed variants of MH on the system.
723 This function looks for MH in `mh-sys-path', `mh-path' and
724 `exec-path'. The format of the list of variants that is returned
725 is described by the variable `mh-variants'."
726 (if mh-variants
727 mh-variants
728 (let ((list-unique))
729 ;; Make a unique list of directories, keeping the given order.
730 ;; We don't want the same MH variant to be listed multiple times.
731 (loop for dir in (append mh-path mh-sys-path exec-path) do
732 (setq dir (file-chase-links (directory-file-name dir)))
733 (add-to-list 'list-unique dir))
734 (loop for dir in (nreverse list-unique) do
735 (when (and dir (file-directory-p dir) (file-readable-p dir))
736 (let ((variant (mh-variant-info dir)))
737 (if variant
738 (add-to-list 'mh-variants variant)))))
739 mh-variants)))
741 (defun mh-variant-info (dir)
742 "Return MH variant found in DIR, or nil if none present."
743 (save-excursion
744 (let ((tmp-buffer (get-buffer-create mh-temp-buffer)))
745 (set-buffer tmp-buffer)
746 (cond
747 ((mh-variant-mh-info dir))
748 ((mh-variant-nmh-info dir))
749 ((mh-variant-mu-mh-info dir))))))
751 (defun mh-variant-mh-info (dir)
752 "Return info for MH variant in DIR assuming a temporary buffer is setup."
753 ;; MH does not have the -version option.
754 ;; Its version number is included in the output of "-help" as:
756 ;; version: MH 6.8.4 #2[UCI] (burrito) of Fri Jan 15 20:01:39 EST 1999
757 ;; options: [ATHENA] [BIND] [DUMB] [LIBLOCKFILE] [LOCALE] [MAILGROUP] [MHE]
758 ;; [MHRC] [MIME] [MORE='"/usr/bin/sensible-pager"'] [NLINK_HACK]
759 ;; [NORUSERPASS] [OVERHEAD] [POP] [POPSERVICE='"pop-3"'] [RENAME]
760 ;; [RFC1342] [RPATHS] [RPOP] [SENDMTS] [SMTP] [SOCKETS]
761 ;; [SPRINTFTYPE=int] [SVR4] [SYS5] [SYS5DIR] [TERMINFO]
762 ;; [TYPESIG=void] [UNISTD] [UTK] [VSPRINTF]
763 (let ((mhparam (expand-file-name "mhparam" dir)))
764 (when (mh-file-command-p mhparam)
765 (erase-buffer)
766 (call-process mhparam nil '(t nil) nil "-help")
767 (goto-char (point-min))
768 (when (search-forward-regexp "version: MH \\(\\S +\\)" nil t)
769 (let ((version (format "MH %s" (match-string 1))))
770 (erase-buffer)
771 (call-process mhparam nil '(t nil) nil "libdir")
772 (goto-char (point-min))
773 (when (search-forward-regexp "^.*$" nil t)
774 (let ((libdir (match-string 0)))
775 `(,version
776 (variant mh)
777 (mh-lib-progs ,libdir)
778 (mh-lib ,libdir)
779 (mh-progs ,dir)
780 (flists nil)))))))))
782 (defun mh-variant-mu-mh-info (dir)
783 "Return info for GNU mailutils variant in DIR.
784 This assumes that a temporary buffer is setup."
785 ;; 'mhparam -version' output:
786 ;; mhparam (GNU mailutils 0.3.2)
787 (let ((mhparam (expand-file-name "mhparam" dir)))
788 (when (mh-file-command-p mhparam)
789 (erase-buffer)
790 (call-process mhparam nil '(t nil) nil "-version")
791 (goto-char (point-min))
792 (when (search-forward-regexp "mhparam (\\(GNU [Mm]ailutils \\S +\\))"
793 nil t)
794 (let ((version (match-string 1))
795 (mh-progs dir))
796 `(,version
797 (variant mu-mh)
798 (mh-lib-progs ,(mh-profile-component "libdir"))
799 (mh-lib ,(mh-profile-component "etcdir"))
800 (mh-progs ,dir)
801 (flists ,(file-exists-p
802 (expand-file-name "flists" dir)))))))))
804 (defun mh-variant-nmh-info (dir)
805 "Return info for nmh variant in DIR assuming a temporary buffer is setup."
806 ;; `mhparam -version' outputs:
807 ;; mhparam -- nmh-1.1-RC1 [compiled on chaak at Fri Jun 20 11:03:28 PDT 2003]
808 (let ((mhparam (expand-file-name "mhparam" dir)))
809 (when (mh-file-command-p mhparam)
810 (erase-buffer)
811 (call-process mhparam nil '(t nil) nil "-version")
812 (goto-char (point-min))
813 (when (search-forward-regexp "mhparam -- nmh-\\(\\S +\\)" nil t)
814 (let ((version (format "nmh %s" (match-string 1)))
815 (mh-progs dir))
816 `(,version
817 (variant nmh)
818 (mh-lib-progs ,(mh-profile-component "libdir"))
819 (mh-lib ,(mh-profile-component "etcdir"))
820 (mh-progs ,dir)
821 (flists ,(file-exists-p
822 (expand-file-name "flists" dir)))))))))
824 (defun mh-file-command-p (file)
825 "Return t if file FILE is the name of a executable regular file."
826 (and (file-regular-p file) (file-executable-p file)))
828 (defun mh-variant-set-variant (variant)
829 "Setup the system variables for the MH variant named VARIANT.
830 If VARIANT is a string, use that key in the alist returned by the
831 function `mh-variants'.
832 If VARIANT is a symbol, select the first entry that matches that
833 variant."
834 (cond
835 ((stringp variant) ;e.g. "nmh 1.1-RC1"
836 (when (assoc variant (mh-variants))
837 (let* ((alist (cdr (assoc variant (mh-variants))))
838 (lib-progs (cadr (assoc 'mh-lib-progs alist)))
839 (lib (cadr (assoc 'mh-lib alist)))
840 (progs (cadr (assoc 'mh-progs alist)))
841 (flists (cadr (assoc 'flists alist))))
842 ;;(set-default mh-variant variant)
843 (setq mh-x-mailer-string nil
844 mh-flists-present-flag flists
845 mh-lib-progs lib-progs
846 mh-lib lib
847 mh-progs progs
848 mh-variant-in-use variant))))
849 ((symbolp variant) ;e.g. 'nmh (pick the first match)
850 (loop for variant-list in (mh-variants)
851 when (eq variant (cadr (assoc 'variant (cdr variant-list))))
852 return (let* ((version (car variant-list))
853 (alist (cdr variant-list))
854 (lib-progs (cadr (assoc 'mh-lib-progs alist)))
855 (lib (cadr (assoc 'mh-lib alist)))
856 (progs (cadr (assoc 'mh-progs alist)))
857 (flists (cadr (assoc 'flists alist))))
858 ;;(set-default mh-variant flavor)
859 (setq mh-x-mailer-string nil
860 mh-flists-present-flag flists
861 mh-lib-progs lib-progs
862 mh-lib lib
863 mh-progs progs
864 mh-variant-in-use version)
865 t)))))
867 (defun mh-variant-p (&rest variants)
868 "Return t if variant is any of VARIANTS.
869 Currently known variants are 'MH, 'nmh, and 'mu-mh."
870 (let ((variant-in-use
871 (cadr (assoc 'variant (assoc mh-variant-in-use (mh-variants))))))
872 (not (null (member variant-in-use variants)))))
874 (defun mh-profile-component (component)
875 "Return COMPONENT value from mhparam, or nil if unset."
876 (save-excursion
877 ;; MH and nmh use -components, Mailutils uses -component. Since MH
878 ;; and nmh work with an unambiguous prefix, the `s' is dropped here.
879 (mh-exec-cmd-quiet nil "mhparam" "-component" component)
880 (mh-profile-component-value component)))
882 (defun mh-profile-component-value (component)
883 "Find and return the value of COMPONENT in the current buffer.
884 Returns nil if the component is not in the buffer."
885 (let ((case-fold-search t))
886 (goto-char (point-min))
887 (cond ((not (re-search-forward (format "^%s:" component) nil t)) nil)
888 ((looking-at "[\t ]*$") nil)
890 (re-search-forward "[\t ]*\\([^\t \n].*\\)$" nil t)
891 (let ((start (match-beginning 1)))
892 (end-of-line)
893 (buffer-substring start (point)))))))
895 (defun mh-variant-set (variant)
896 "Set the MH variant to VARIANT.
897 Sets `mh-progs', `mh-lib', `mh-lib-progs' and
898 `mh-flists-present-flag'.
899 If the VARIANT is \"autodetect\", then first try nmh, then MH and
900 finally GNU mailutils."
901 (interactive
902 (list (completing-read
903 "MH variant: "
904 (mapcar (lambda (x) (list (car x))) (mh-variants))
905 nil t)))
906 (let ((valid-list (mapcar (lambda (x) (car x)) (mh-variants))))
907 (cond
908 ((eq variant 'none))
909 ((eq variant 'autodetect)
910 (cond
911 ((mh-variant-set-variant 'nmh)
912 (message "%s installed as MH variant" mh-variant-in-use))
913 ((mh-variant-set-variant 'mh)
914 (message "%s installed as MH variant" mh-variant-in-use))
915 ((mh-variant-set-variant 'mu-mh)
916 (message "%s installed as MH variant" mh-variant-in-use))
918 (message "No MH variant found on the system"))))
919 ((member variant valid-list)
920 (when (not (mh-variant-set-variant variant))
921 (message "Warning: %s variant not found. Autodetecting..." variant)
922 (mh-variant-set 'autodetect)))
924 (message "Unknown variant; use %s"
925 (mapconcat '(lambda (x) (format "%s" (car x)))
926 (mh-variants) " or "))))))
928 (defcustom-mh mh-variant 'autodetect
929 "*Specifies the variant used by MH-E.
931 The default setting of this option is \"Auto-detect\" which means
932 that MH-E will automatically choose the first of nmh, MH, or GNU
933 mailutils that it finds in the directories listed in
934 `mh-path' (which you can customize), `mh-sys-path', and
935 `exec-path'. If MH-E can't find MH at all, you may have to
936 customize `mh-path' and add the directory in which the command
937 \"mhparam\" is located. If, on the other hand, you have both nmh
938 and mailutils installed (for example) and `mh-variant-in-use' was
939 initialized to nmh but you want to use mailutils, then you can
940 set this option to \"mailutils\".
942 When this variable is changed, MH-E resets `mh-progs', `mh-lib',
943 `mh-lib-progs', `mh-flists-present-flag', and `mh-variant-in-use'
944 accordingly. Prior to version 8, it was often necessary to set
945 some of these variables in \"~/.emacs\"; now it is no longer
946 necessary and can actually cause problems."
947 :type `(radio
948 (const :tag "Auto-detect" autodetect)
949 ,@(mapcar (lambda (x) `(const ,(car x))) (mh-variants)))
950 :set (lambda (symbol value)
951 (set-default symbol value) ;Done in mh-variant-set-variant!
952 (mh-variant-set value))
953 :group 'mh-e
954 :package-version '(MH-E "8.0"))
958 ;;; MH-E Customization
960 ;; All of the defgroups, defcustoms, and deffaces in MH-E are found
961 ;; here. This makes it possible to customize modules that aren't
962 ;; loaded yet. It also makes it easier to organize the customization
963 ;; groups.
965 ;; This section contains the following sub-sections:
967 ;; 1. MH-E Customization Groups
969 ;; These are the customization group definitions. Every group has a
970 ;; associated manual node. The ordering is alphabetical, except for
971 ;; the groups mh-faces and mh-hooks which are last .
973 ;; 2. MH-E Customization
975 ;; These are the actual customization variables. There is a
976 ;; sub-section for each group in the MH-E Customization Groups
977 ;; section, in the same order, separated by page breaks. Within
978 ;; each section, variables are sorted alphabetically.
980 ;; 3. Hooks
982 ;; All hooks must be placed in the mh-hook group; in addition, add
983 ;; the group associated with the manual node in which the hook is
984 ;; described. Since the mh-hook group appears near the end of this
985 ;; section, the hooks will appear at the end of these other groups.
987 ;; 4. Faces
989 ;; All faces must be placed in the mh-faces group; in addition, add
990 ;; the group associated with the manual node in which the face is
991 ;; described. Since the mh-faces group appears near the end of this
992 ;; section, the faces will appear at the end of these other groups.
994 (defun mh-customize (&optional delete-other-windows-flag)
995 "Customize MH-E variables.
996 If optional argument DELETE-OTHER-WINDOWS-FLAG is non-nil, other
997 windows in the frame are removed."
998 (interactive "P")
999 (customize-group 'mh-e)
1000 (when delete-other-windows-flag
1001 (delete-other-windows)))
1003 (if (boundp 'customize-package-emacs-version-alist)
1004 (add-to-list 'customize-package-emacs-version-alist
1005 '(MH-E ("6.0" . "22.1") ("6.1" . "22.1") ("7.0" . "22.1")
1006 ("7.1" . "22.1") ("7.2" . "22.1") ("7.3" . "22.1")
1007 ("7.4" . "22.1") ("8.0" . "22.1"))))
1011 ;;; MH-E Customization Groups
1013 (defgroup-mh mh-e nil
1014 "Emacs interface to the MH mail system.
1015 MH is the Rand Mail Handler. Other implementations include nmh
1016 and GNU mailutils."
1017 :link '(custom-manual "(mh-e)Top")
1018 :group 'mail
1019 :package-version '(MH-E . "8.0"))
1021 (defgroup-mh mh-alias nil
1022 "Aliases."
1023 :link '(custom-manual "(mh-e)Aliases")
1024 :prefix "mh-alias-"
1025 :group 'mh-e
1026 :package-version '(MH-E . "7.1"))
1028 (defgroup-mh mh-folder nil
1029 "Organizing your mail with folders."
1030 :prefix "mh-"
1031 :link '(custom-manual "(mh-e)Folders")
1032 :group 'mh-e
1033 :package-version '(MH-E . "7.1"))
1035 (defgroup-mh mh-folder-selection nil
1036 "Folder selection."
1037 :prefix "mh-"
1038 :link '(custom-manual "(mh-e)Folder Selection")
1039 :group 'mh-e
1040 :package-version '(MH-E . "8.0"))
1042 (defgroup-mh mh-identity nil
1043 "Identities."
1044 :link '(custom-manual "(mh-e)Identities")
1045 :prefix "mh-identity-"
1046 :group 'mh-e
1047 :package-version '(MH-E . "7.1"))
1049 (defgroup-mh mh-inc nil
1050 "Incorporating your mail."
1051 :prefix "mh-inc-"
1052 :link '(custom-manual "(mh-e)Incorporating Mail")
1053 :group 'mh-e
1054 :package-version '(MH-E . "8.0"))
1056 (defgroup-mh mh-junk nil
1057 "Dealing with junk mail."
1058 :link '(custom-manual "(mh-e)Junk")
1059 :prefix "mh-junk-"
1060 :group 'mh-e
1061 :package-version '(MH-E . "7.3"))
1063 (defgroup-mh mh-letter nil
1064 "Editing a draft."
1065 :prefix "mh-"
1066 :link '(custom-manual "(mh-e)Editing Drafts")
1067 :group 'mh-e
1068 :package-version '(MH-E . "7.1"))
1070 (defgroup-mh mh-ranges nil
1071 "Ranges."
1072 :prefix "mh-"
1073 :link '(custom-manual "(mh-e)Ranges")
1074 :group 'mh-e
1075 :package-version '(MH-E . "8.0"))
1077 (defgroup-mh mh-scan-line-formats nil
1078 "Scan line formats."
1079 :link '(custom-manual "(mh-e)Scan Line Formats")
1080 :prefix "mh-"
1081 :group 'mh-e
1082 :package-version '(MH-E . "8.0"))
1084 (defgroup-mh mh-search nil
1085 "Searching."
1086 :link '(custom-manual "(mh-e)Searching")
1087 :prefix "mh-search-"
1088 :group 'mh-e
1089 :package-version '(MH-E . "8.0"))
1091 (defgroup-mh mh-sending-mail nil
1092 "Sending mail."
1093 :prefix "mh-"
1094 :link '(custom-manual "(mh-e)Sending Mail")
1095 :group 'mh-e
1096 :package-version '(MH-E . "8.0"))
1098 (defgroup-mh mh-sequences nil
1099 "Sequences."
1100 :prefix "mh-"
1101 :link '(custom-manual "(mh-e)Sequences")
1102 :group 'mh-e
1103 :package-version '(MH-E . "8.0"))
1105 (defgroup-mh mh-show nil
1106 "Reading your mail."
1107 :prefix "mh-"
1108 :link '(custom-manual "(mh-e)Reading Mail")
1109 :group 'mh-e
1110 :package-version '(MH-E . "7.1"))
1112 (defgroup-mh mh-speedbar nil
1113 "The speedbar."
1114 :prefix "mh-speed-"
1115 :link '(custom-manual "(mh-e)Speedbar")
1116 :group 'mh-e
1117 :package-version '(MH-E . "8.0"))
1119 (defgroup-mh mh-thread nil
1120 "Threading."
1121 :prefix "mh-thread-"
1122 :link '(custom-manual "(mh-e)Threading")
1123 :group 'mh-e
1124 :package-version '(MH-E . "8.0"))
1126 (defgroup-mh mh-tool-bar nil
1127 "The tool bar"
1128 :link '(custom-manual "(mh-e)Tool Bar")
1129 :prefix "mh-"
1130 :group 'mh-e
1131 :package-version '(MH-E . "8.0"))
1133 (defgroup-mh mh-hooks nil
1134 "MH-E hooks."
1135 :link '(custom-manual "(mh-e)Top")
1136 :prefix "mh-"
1137 :group 'mh-e
1138 :package-version '(MH-E . "7.1"))
1140 (defgroup-mh mh-faces nil
1141 "Faces used in MH-E."
1142 :link '(custom-manual "(mh-e)Top")
1143 :prefix "mh-"
1144 :group 'faces
1145 :group 'mh-e
1146 :package-version '(MH-E . "7.1"))
1150 ;;; MH-E Customization
1152 ;; See Variant Support, above, for mh-e group.
1154 ;;; Aliases (:group 'mh-alias)
1156 (defcustom-mh mh-alias-completion-ignore-case-flag t
1157 "*Non-nil means don't consider case significant in MH alias completion.
1159 As MH ignores case in the aliases, so too does MH-E. However, you
1160 may turn off this option to make case significant which can be
1161 used to segregate completion of your aliases. You might use
1162 lowercase for mailing lists and uppercase for people."
1163 :type 'boolean
1164 :group 'mh-alias
1165 :package-version '(MH-E . "7.1"))
1167 (defcustom-mh mh-alias-expand-aliases-flag nil
1168 "*Non-nil means to expand aliases entered in the minibuffer.
1170 In other words, aliases entered in the minibuffer will be
1171 expanded to the full address in the message draft. By default,
1172 this expansion is not performed."
1173 :type 'boolean
1174 :group 'mh-alias
1175 :package-version '(MH-E . "7.1"))
1177 (defcustom-mh mh-alias-flash-on-comma t
1178 "*Specify whether to flash address or warn on translation.
1180 This option controls the behavior when a [comma] is pressed while
1181 entering aliases or addresses. The default setting flashes the
1182 address associated with an address in the minibuffer briefly, but
1183 does not display a warning if the alias is not found."
1184 :type '(choice (const :tag "Flash but Don't Warn If No Alias" t)
1185 (const :tag "Flash and Warn If No Alias" 1)
1186 (const :tag "Don't Flash Nor Warn If No Alias" nil))
1187 :group 'mh-alias
1188 :package-version '(MH-E . "7.1"))
1190 (defcustom-mh mh-alias-insert-file nil
1191 "*Filename used to store a new MH-E alias.
1193 The default setting of this option is \"Use Aliasfile Profile
1194 Component\". This option can also hold the name of a file or a
1195 list a file names. If this option is set to a list of file names,
1196 or the \"Aliasfile:\" profile component contains more than one file
1197 name, MH-E will prompt for one of them when MH-E adds an alias."
1198 :type '(choice (const :tag "Use Aliasfile Profile Component" nil)
1199 (file :tag "Alias File")
1200 (repeat :tag "List of Alias Files" file))
1201 :group 'mh-alias
1202 :package-version '(MH-E . "7.1"))
1204 (defcustom-mh mh-alias-insertion-location 'sorted
1205 "Specifies where new aliases are entered in alias files.
1207 This option is set to \"Alphabetical\" by default. If you organize
1208 your alias file in other ways, then adding aliases to the \"Top\"
1209 or \"Bottom\" of your alias file might be more appropriate."
1210 :type '(choice (const :tag "Alphabetical" sorted)
1211 (const :tag "Top" top)
1212 (const :tag "Bottom" bottom))
1213 :group 'mh-alias
1214 :package-version '(MH-E . "7.1"))
1216 (defcustom-mh mh-alias-local-users t
1217 "*Non-nil means local users are added to alias completion.
1219 Aliases are created from \"/etc/passwd\" entries with a user ID
1220 larger than a magical number, typically 200. This can be a handy
1221 tool on a machine where you and co-workers exchange messages.
1222 These aliases have the form \"local.first.last\" if a real name is
1223 present in the password file. Otherwise, the alias will have the
1224 form \"local.login\".
1226 If you're on a system with thousands of users you don't know, and
1227 the loading of local aliases slows MH-E down noticeably, then
1228 turn this option off.
1230 This option also takes a string which is executed to generate the
1231 password file. For example, use \"ypcat passwd\" to obtain the
1232 NIS password file."
1233 :type '(choice (boolean) (string))
1234 :group 'mh-alias
1235 :package-version '(MH-E . "7.1"))
1237 (defcustom-mh mh-alias-local-users-prefix "local."
1238 "*String prefixed to the real names of users from the password file.
1239 This option can also be set to \"Use Login\".
1241 For example, consider the following password file entry:
1243 psg:x:1000:1000:Peter S Galbraith,,,:/home/psg:/bin/tcsh
1245 The following settings of this option will produce the associated
1246 aliases:
1248 \"local.\" local.peter.galbraith
1249 \"\" peter.galbraith
1250 Use Login psg
1252 This option has no effect if variable `mh-alias-local-users' is
1253 turned off."
1254 :type '(choice (const :tag "Use Login" nil)
1255 (string))
1256 :group 'mh-alias
1257 :package-version '(MH-E . "7.4"))
1259 (defcustom-mh mh-alias-passwd-gecos-comma-separator-flag t
1260 "*Non-nil means the gecos field in the password file uses a comma separator.
1262 In the example in `mh-alias-local-users-prefix', commas are used
1263 to separate different values within the so-called gecos field.
1264 This is a fairly common usage. However, in the rare case that the
1265 gecos field in your password file is not separated by commas and
1266 whose contents may contain commas, you can turn this option off."
1267 :type 'boolean
1268 :group 'mh-alias
1269 :package-version '(MH-E . "7.4"))
1271 ;;; Organizing Your Mail with Folders (:group 'mh-folder)
1273 (defcustom-mh mh-new-messages-folders t
1274 "Folders searched for the \"unseen\" sequence.
1276 Set this option to \"Inbox\" to search the \"+inbox\" folder or
1277 \"All\" to search all of the top level folders. Otherwise, list
1278 the folders that should be searched with the \"Choose Folders\"
1279 menu item.
1281 See also `mh-recursive-folders-flag'."
1282 :type '(choice (const :tag "Inbox" t)
1283 (const :tag "All" nil)
1284 (repeat :tag "Choose Folders" (string :tag "Folder")))
1285 :group 'mh-folder
1286 :package-version '(MH-E . "8.0"))
1288 (defcustom-mh mh-ticked-messages-folders t
1289 "Folders searched for `mh-tick-seq'.
1291 Set this option to \"Inbox\" to search the \"+inbox\" folder or
1292 \"All\" to search all of the top level folders. Otherwise, list
1293 the folders that should be searched with the \"Choose Folders\"
1294 menu item.
1296 See also `mh-recursive-folders-flag'."
1297 :type '(choice (const :tag "Inbox" t)
1298 (const :tag "All" nil)
1299 (repeat :tag "Choose Folders" (string :tag "Folder")))
1300 :group 'mh-folder
1301 :package-version '(MH-E . "8.0"))
1303 (defcustom-mh mh-large-folder 200
1304 "The number of messages that indicates a large folder.
1306 If a folder is deemed to be large, that is the number of messages
1307 in it exceed this value, then confirmation is needed when it is
1308 visited. Even when `mh-show-threads-flag' is non-nil, the folder
1309 is not automatically threaded, if it is large. If set to nil all
1310 folders are treated as if they are small."
1311 :type '(choice (const :tag "No Limit") integer)
1312 :group 'mh-folder
1313 :package-version '(MH-E . "7.0"))
1315 (defcustom-mh mh-recenter-summary-flag nil
1316 "*Non-nil means to recenter the summary window.
1318 If this option is turned on, recenter the summary window when the
1319 show window is toggled off."
1320 :type 'boolean
1321 :group 'mh-folder
1322 :package-version '(MH-E . "7.0"))
1324 (defcustom-mh mh-recursive-folders-flag nil
1325 "*Non-nil means that commands which operate on folders do so recursively."
1326 :type 'boolean
1327 :group 'mh-folder
1328 :package-version '(MH-E . "7.0"))
1330 (defcustom-mh mh-sortm-args nil
1331 "*Additional arguments for \"sortm\"\\<mh-folder-mode-map>.
1333 This option is consulted when a prefix argument is used with
1334 \\[mh-sort-folder]. Normally default arguments to \"sortm\" are
1335 specified in the MH profile. This option may be used to provide
1336 an alternate view. For example, \"'(\"-nolimit\" \"-textfield\"
1337 \"subject\")\" is a useful setting."
1338 :type 'string
1339 :group 'mh-folder
1340 :package-version '(MH-E . "8.0"))
1342 ;;; Folder Selection (:group 'mh-folder-selection)
1344 (defcustom-mh mh-default-folder-for-message-function nil
1345 "Function to select a default folder for refiling or \"Fcc:\".
1347 When this function is called, the current buffer contains the message
1348 being refiled and point is at the start of the message. This function
1349 should return the default folder as a string with a leading \"+\"
1350 sign. It can also return nil so that the last folder name is used as
1351 the default, or an empty string to suppress the default entirely."
1352 :type 'function
1353 :group 'mh-folder-selection
1354 :package-version '(MH-E . "8.0"))
1356 (defcustom-mh mh-default-folder-list nil
1357 "*List of addresses and folders.
1359 The folder name associated with the first address found in this
1360 list is used as the default for `mh-refile-msg' and similar
1361 functions. Each element in this list contains a \"Check Recipient\"
1362 item. If this item is turned on, then the address is checked
1363 against the recipient instead of the sender. This is useful for
1364 mailing lists.
1366 See `mh-prompt-for-refile-folder' and `mh-folder-from-address'
1367 for more information."
1368 :type '(repeat (list (regexp :tag "Address")
1369 (string :tag "Folder")
1370 (boolean :tag "Check Recipient")))
1371 :group 'mh-folder-selection
1372 :package-version '(MH-E . "7.2"))
1374 (defcustom-mh mh-default-folder-must-exist-flag t
1375 "*Non-nil means guessed folder name must exist to be used.
1377 If the derived folder does not exist, and this option is on, then
1378 the last folder name used is suggested. This is useful if you get
1379 mail from various people for whom you have an alias, but file
1380 them all in the same project folder.
1382 See `mh-prompt-for-refile-folder' and `mh-folder-from-address'
1383 for more information."
1384 :type 'boolean
1385 :group 'mh-folder-selection
1386 :package-version '(MH-E . "7.2"))
1388 (defcustom-mh mh-default-folder-prefix ""
1389 "*Prefix used for folder names generated from aliases.
1390 The prefix is used to prevent clutter in your mail directory.
1392 See `mh-prompt-for-refile-folder' and `mh-folder-from-address'
1393 for more information."
1394 :type 'string
1395 :group 'mh-folder-selection
1396 :package-version '(MH-E . "7.2"))
1398 ;;; Identities (:group 'mh-identity)
1400 (eval-and-compile
1401 (unless (fboundp 'mh-identity-make-menu-no-autoload)
1402 (defun mh-identity-make-menu-no-autoload ()
1403 "Temporary definition.
1404 Real definition will take effect when mh-identity is loaded."
1405 nil)))
1407 (defcustom-mh mh-identity-list nil
1408 "*List of identities.
1410 To customize this option, click on the \"INS\" button and enter a label
1411 such as \"Home\" or \"Work\". Then click on the \"INS\" button with the
1412 label \"Add at least one item below\". Then choose one of the items in
1413 the \"Value Menu\".
1415 You can specify an alternate \"From:\" header field using the \"From
1416 Field\" menu item. You must include a valid email address. A standard
1417 format is \"First Last <login@@host.domain>\". If you use an initial
1418 with a period, then you must quote your name as in '\"First I. Last\"
1419 <login@@host.domain>'. People usually list the name of the company
1420 where they work using the \"Organization Field\" menu item. Set any
1421 arbitrary header field and value in the \"Other Field\" menu item.
1422 Unless the header field is a standard one, precede the name of your
1423 field's label with \"X-\", as in \"X-Fruit-of-the-Day:\". The value of
1424 \"Attribution Verb\" overrides the setting of
1425 `mh-extract-from-attribution-verb'. Set your signature with the
1426 \"Signature\" menu item. You can specify the contents of
1427 `mh-signature-file-name', a file, or a function. Specify a different
1428 key to sign or encrypt messages with the \"GPG Key ID\" menu item.
1430 You can select the identities you have added via the menu called
1431 \"Identity\" in the MH-Letter buffer. You can also use
1432 \\[mh-insert-identity]. To clear the fields and signature added by the
1433 identity, select the \"None\" identity.
1435 The \"Identity\" menu contains two other items to save you from having
1436 to set the identity on every message. The menu item \"Set Default for
1437 Session\" can be used to set the default identity to the current
1438 identity until you exit Emacs. The menu item \"Save as Default\" sets
1439 the option `mh-identity-default' to the current identity setting. You
1440 can also customize the `mh-identity-default' option in the usual
1441 fashion."
1442 :type '(repeat (list :tag ""
1443 (string :tag "Label")
1444 (repeat :tag "Add at least one item below"
1445 (choice
1446 (cons :tag "From Field"
1447 (const "From")
1448 (string :tag "Value"))
1449 (cons :tag "Organization Field"
1450 (const "Organization")
1451 (string :tag "Value"))
1452 (cons :tag "Other Field"
1453 (string :tag "Field")
1454 (string :tag "Value"))
1455 (cons :tag "Attribution Verb"
1456 (const ":attribution-verb")
1457 (string :tag "Value"))
1458 (cons :tag "Signature"
1459 (const :tag "Signature"
1460 ":signature")
1461 (choice
1462 (const :tag "mh-signature-file-name"
1463 nil)
1464 (file)
1465 (function)))
1466 (cons :tag "GPG Key ID"
1467 (const :tag "GPG Key ID"
1468 ":pgg-default-user-id")
1469 (string :tag "Value"))))))
1470 :set (lambda (symbol value)
1471 (set-default symbol value)
1472 (mh-identity-make-menu-no-autoload))
1473 :group 'mh-identity
1474 :package-version '(MH-E . "7.1"))
1476 (defcustom-mh mh-auto-fields-list nil
1477 "List of recipients for which header lines are automatically inserted.
1479 This option can be used to set the identity depending on the
1480 recipient. To customize this option, click on the \"INS\" button and
1481 enter a regular expression for the recipient's address. Click on the
1482 \"INS\" button with the \"Add at least one item below\" label. Then choose
1483 one of the items in the \"Value Menu\".
1485 The \"Identity\" menu item is used to select an identity from those
1486 configured in `mh-identity-list'. All of the information for that
1487 identity will be added if the recipient matches. The \"Fcc Field\" menu
1488 item is used to select a folder that is used in the \"Fcc:\" header.
1489 When you send the message, MH will put a copy of your message in this
1490 folder. The \"Mail-Followup-To Field\" menu item is used to insert an
1491 \"Mail-Followup-To:\" header field with the recipients you provide. If
1492 the recipient's mail user agent supports this header field (as nmh
1493 does), then their replies will go to the addresses listed. This is
1494 useful if their replies go both to the list and to you and you don't
1495 have a mechanism to suppress duplicates. If you reply to someone not
1496 on the list, you must either remove the \"Mail-Followup-To:\" field, or
1497 ensure the recipient is also listed there so that he receives replies
1498 to your reply. Other header fields may be added using the \"Other
1499 Field\" menu item.
1501 These fields can only be added after the recipient is known. Once the
1502 header contains one or more recipients, run the
1503 \\[mh-insert-auto-fields] command or choose the \"Identity -> Insert
1504 Auto Fields\" menu item to insert these fields manually. However, you
1505 can just send the message and the fields will be added automatically.
1506 You are given a chance to see these fields and to confirm them before
1507 the message is actually sent. You can do away with this confirmation
1508 by turning off the option `mh-auto-fields-prompt-flag'.
1510 You should avoid using the same header field in `mh-auto-fields-list'
1511 and `mh-identity-list' definitions that may apply to the same message
1512 as the result is undefined."
1513 :type `(repeat
1514 (list :tag ""
1515 (string :tag "Recipient")
1516 (repeat :tag "Add at least one item below"
1517 (choice
1518 (cons :tag "Identity"
1519 (const ":identity")
1520 ,(append
1521 '(radio)
1522 (mapcar
1523 (function (lambda (arg) `(const ,arg)))
1524 (mapcar 'car mh-identity-list))))
1525 (cons :tag "Fcc Field"
1526 (const "fcc")
1527 (string :tag "Value"))
1528 (cons :tag "Mail-Followup-To Field"
1529 (const "Mail-Followup-To")
1530 (string :tag "Value"))
1531 (cons :tag "Other Field"
1532 (string :tag "Field")
1533 (string :tag "Value"))))))
1534 :group 'mh-identity
1535 :package-version '(MH-E . "7.3"))
1537 (defcustom-mh mh-auto-fields-prompt-flag t
1538 "*Non-nil means to prompt before sending if fields inserted.
1539 See `mh-auto-fields-list'."
1540 :type 'boolean
1541 :group 'mh-identity
1542 :package-version '(MH-E . "8.0"))
1544 (defcustom-mh mh-identity-default nil
1545 "Default identity to use when `mh-letter-mode' is called.
1546 See `mh-identity-list'."
1547 :type (append
1548 '(radio)
1549 (cons '(const :tag "None" nil)
1550 (mapcar (function (lambda (arg) `(const ,arg)))
1551 (mapcar 'car mh-identity-list))))
1552 :group 'mh-identity
1553 :package-version '(MH-E . "7.1"))
1555 (defcustom-mh mh-identity-handlers
1556 '(("From" . mh-identity-handler-top)
1557 (":default" . mh-identity-handler-bottom)
1558 (":attribution-verb" . mh-identity-handler-attribution-verb)
1559 (":signature" . mh-identity-handler-signature)
1560 (":pgg-default-user-id" . mh-identity-handler-gpg-identity))
1561 "Handler functions for fields in `mh-identity-list'.
1563 This option is used to change the way that fields, signatures,
1564 and attributions in `mh-identity-list' are added. To customize
1565 `mh-identity-handlers', replace the name of an existing handler
1566 function associated with the field you want to change with the
1567 name of a function you have written. You can also click on an
1568 \"INS\" button and insert a field of your choice and the name of
1569 the function you have written to handle it.
1571 The \"Field\" field can be any field that you've used in your
1572 `mh-identity-list'. The special fields \":attribution-verb\",
1573 \":signature\", or \":pgg-default-user-id\" are used for the
1574 `mh-identity-list' choices \"Attribution Verb\", \"Signature\", and
1575 \"GPG Key ID\" respectively.
1577 The handler associated with the \":default\" field is used when no
1578 other field matches.
1580 The handler functions are passed two or three arguments: the
1581 FIELD itself (for example, \"From\"), or one of the special
1582 fields (for example, \":signature\"), and the ACTION 'remove or
1583 'add. If the action is 'add, an additional argument
1584 containing the VALUE for the field is given."
1585 :type '(repeat (cons (string :tag "Field") function))
1586 :group 'mh-identity
1587 :package-version '(MH-E . "8.0"))
1589 ;;; Incorporating Your Mail (:group 'mh-inc)
1591 (defcustom-mh mh-inc-prog "inc"
1592 "*Program to incorporate new mail into a folder.
1594 This program generates a one-line summary for each of the new
1595 messages. Unless it is an absolute pathname, the file is assumed
1596 to be in the `mh-progs' directory. You may also link a file to
1597 \"inc\" that uses a different format. You'll then need to modify
1598 several scan line format variables appropriately."
1599 :type 'string
1600 :group 'mh-inc
1601 :package-version '(MH-E . "6.0"))
1603 (eval-and-compile
1604 (unless (fboundp 'mh-inc-spool-make-no-autoload)
1605 (defun mh-inc-spool-make-no-autoload ()
1606 "Temporary definition.
1607 Real definition will take effect when mh-inc is loaded."
1608 nil)))
1610 (defcustom-mh mh-inc-spool-list nil
1611 "*Alternate spool files.
1613 You can use the `mh-inc-spool-list' variable to direct MH-E to
1614 retrieve mail from arbitrary spool files other than your system
1615 mailbox, file it in folders other than your \"+inbox\", and assign
1616 key bindings to incorporate this mail.
1618 Suppose you are subscribed to the \"mh-e-devel\" mailing list and
1619 you use \"procmail\" to filter this mail into \"~/mail/mh-e\" with
1620 the following recipe in \".procmailrc\":
1622 MAILDIR=$HOME/mail
1624 * ^From mh-e-devel-admin@stop.mail-abuse.org
1625 mh-e
1627 In order to incorporate \"~/mail/mh-e\" into \"+mh-e\" with an
1628 \"I m\" (mh-inc-spool-mh-e) command, customize this option, and click
1629 on the \"INS\" button. Enter a \"Spool File\" of \"~/mail/mh-e\", a
1630 \"Folder\" of \"mh-e\", and a \"Key Binding\" of \"m\".
1632 You can use \"xbuffy\" to automate the incorporation of this mail
1633 using the Emacs 22 command \"emacsclient\" as follows:
1635 box ~/mail/mh-e
1636 title mh-e
1637 origMode
1638 polltime 10
1639 headertime 0
1640 command emacsclient --eval '(mh-inc-spool-mh-e)'
1642 In XEmacs, the command \"gnuclient\" is used in a similar
1643 fashion."
1644 :type '(repeat (list (file :tag "Spool File")
1645 (string :tag "Folder")
1646 (character :tag "Key Binding")))
1647 :set (lambda (symbol value)
1648 (set-default symbol value)
1649 (mh-inc-spool-make-no-autoload))
1650 :group 'mh-inc
1651 :package-version '(MH-E . "7.3"))
1653 ;;; Dealing with Junk Mail (:group 'mh-junk)
1655 (defvar mh-junk-choice nil
1656 "Chosen spam fighting program.")
1658 ;; Available spam filter interfaces
1659 (defvar mh-junk-function-alist
1660 '((spamassassin mh-spamassassin-blacklist mh-spamassassin-whitelist)
1661 (bogofilter mh-bogofilter-blacklist mh-bogofilter-whitelist)
1662 (spamprobe mh-spamprobe-blacklist mh-spamprobe-whitelist))
1663 "Available choices of spam programs to use.
1665 This is an alist. For each element there are functions that
1666 blacklist a message as spam and whitelist a message incorrectly
1667 classified as spam.")
1669 (defun mh-junk-choose (symbol value)
1670 "Choose spam program to use.
1672 The function is always called with SYMBOL bound to
1673 `mh-junk-program' and VALUE bound to the new value of
1674 `mh-junk-program'. The function sets the variable
1675 `mh-junk-choice' in addition to `mh-junk-program'."
1676 (set symbol value) ;XXX shouldn't this be set-default?
1677 (setq mh-junk-choice
1678 (or value
1679 (loop for element in mh-junk-function-alist
1680 until (executable-find (symbol-name (car element)))
1681 finally return (car element)))))
1683 (defcustom-mh mh-junk-background nil
1684 "If on, spam programs are run in background.
1686 By default, the programs are run in the foreground, but this can
1687 be slow when junking large numbers of messages. If you have
1688 enough memory or don't junk that many messages at the same time,
1689 you might try turning on this option.
1691 Note that this option is used as the \"display\" argument in the
1692 call to `call-process'. Therefore, turning on this option means
1693 setting its value to \"0\". You can also set its value to t to
1694 direct the programs' output to the \"*MH-E Log*\" buffer; this
1695 may be useful for debugging."
1696 :type '(choice (const :tag "Off" nil)
1697 (const :tag "On" 0))
1698 :group 'mh-junk
1699 :package-version '(MH-E . "8.0"))
1701 (defcustom-mh mh-junk-disposition nil
1702 "Disposition of junk mail."
1703 :type '(choice (const :tag "Delete Spam" nil)
1704 (string :tag "Spam Folder"))
1705 :group 'mh-junk
1706 :package-version '(MH-E . "8.0"))
1708 (defcustom-mh mh-junk-program nil
1709 "Spam program that MH-E should use.
1711 The default setting of this option is \"Auto-detect\" which means
1712 that MH-E will automatically choose one of SpamAssassin,
1713 bogofilter, or SpamProbe in that order. If, for example, you have
1714 both SpamAssassin and bogofilter installed and you want to use
1715 bogofilter, then you can set this option to \"Bogofilter\"."
1716 :type '(choice (const :tag "Auto-detect" nil)
1717 (const :tag "SpamAssassin" spamassassin)
1718 (const :tag "Bogofilter" bogofilter)
1719 (const :tag "SpamProbe" spamprobe))
1720 :set 'mh-junk-choose
1721 :group 'mh-junk
1722 :package-version '(MH-E . "7.3"))
1724 ;;; Editing a Draft (:group 'mh-letter)
1726 (defcustom-mh mh-compose-insertion (if (locate-library "mml") 'mml 'mh)
1727 "Type of tags used when composing MIME messages.
1729 In addition to MH-style directives, MH-E also supports MML (MIME
1730 Meta Language) tags. (see Info node `(emacs-mime)Composing').
1731 This option can be used to choose between them. By default, this
1732 option is set to \"MML\" if it is supported since it provides a
1733 lot more functionality. This option can also be set to \"MH\" if
1734 MH-style directives are preferred."
1735 :type '(choice (const :tag "MML" mml)
1736 (const :tag "MH" mh))
1737 :group 'mh-letter
1738 :package-version '(MH-E . "7.0"))
1740 (defcustom-mh mh-compose-skipped-header-fields
1741 '("From" "Organization" "References" "In-Reply-To"
1742 "X-Face" "Face" "X-Image-URL" "X-Mailer")
1743 "List of header fields to skip over when navigating in draft."
1744 :type '(repeat (string :tag "Field"))
1745 :group 'mh-letter
1746 :package-version '(MH-E . "7.4"))
1748 (defcustom-mh mh-compose-space-does-completion-flag nil
1749 "*Non-nil means \\<mh-letter-mode-map>\\[mh-letter-complete-or-space] does completion in message header."
1750 :type 'boolean
1751 :group 'mh-letter
1752 :package-version '(MH-E . "7.4"))
1754 (defcustom-mh mh-delete-yanked-msg-window-flag nil
1755 "*Non-nil means delete any window displaying the message.
1757 This deletes the window containing the original message after
1758 yanking it with \\<mh-letter-mode-map>\\[mh-yank-cur-msg] to make
1759 more room on your screen for your reply."
1760 :type 'boolean
1761 :group 'mh-letter
1762 :package-version '(MH-E . "7.0"))
1764 (defcustom-mh mh-extract-from-attribution-verb "wrote:"
1765 "*Verb to use for attribution when a message is yanked by \\<mh-letter-mode-map>\\[mh-yank-cur-msg].
1767 The attribution consists of the sender's name and email address
1768 followed by the content of this option. This option can be set to
1769 \"wrote:\", \"a écrit:\", and \"schrieb:\". You can also use the
1770 \"Custom String\" menu item to enter your own verb."
1771 :type '(choice (const "wrote:")
1772 (const "a écrit:")
1773 (const "schrieb:")
1774 (string :tag "Custom String"))
1775 :group 'mh-letter
1776 :package-version '(MH-E . "7.0"))
1778 (defcustom-mh mh-ins-buf-prefix "> "
1779 "*String to put before each line of a yanked or inserted message.
1781 The prefix \"> \" is the default setting of this option. I
1782 suggest that you not modify this option since it is used by many
1783 mailers and news readers: messages are far easier to read if
1784 several included messages have all been indented by the same
1785 string.
1787 This prefix is not inserted if you use one of the supercite
1788 flavors of `mh-yank-behavior' or you have added a
1789 `mail-citation-hook'."
1790 :type 'string
1791 :group 'mh-letter
1792 :package-version '(MH-E . "6.0"))
1794 (defcustom-mh mh-letter-complete-function 'ispell-complete-word
1795 "*Function to call when completing outside of address or folder fields.
1797 In the body of the message,
1798 \\<mh-letter-mode-map>\\[mh-letter-complete] runs this function,
1799 which is set to \"ispell-complete-word\" by default."
1800 :type '(choice function (const nil))
1801 :group 'mh-letter
1802 :package-version '(MH-E . "7.1"))
1804 (defcustom-mh mh-letter-fill-column 72
1805 "*Fill column to use in MH Letter mode.
1807 By default, this option is 72 to allow others to quote your
1808 message without line wrapping."
1809 :type 'integer
1810 :group 'mh-letter
1811 :package-version '(MH-E . "6.0"))
1813 (defcustom-mh mh-mml-method-default (if mh-pgp-support-flag "pgpmime" "none")
1814 "Default method to use in security tags.
1816 This option is used to select between a variety of mail security
1817 mechanisms. The default is \"PGP (MIME)\" if it is supported\;
1818 otherwise, the default is \"None\". Other mechanisms include
1819 vanilla \"PGP\" and \"S/MIME\".
1821 The `pgg' customization group may have some settings which may
1822 interest you (see Info node `(pgg)').
1824 In particular, I turn on the option `pgg-encrypt-for-me' so that
1825 all messages I encrypt are encrypted with my public key as well.
1826 If you keep a copy of all of your outgoing mail with a \"Fcc:\"
1827 header field, this setting is vital so that you can read the mail
1828 you write!"
1829 :type '(choice (const :tag "PGP (MIME)" "pgpmime")
1830 (const :tag "PGP" "pgp")
1831 (const :tag "S/MIME" "smime")
1832 (const :tag "None" "none"))
1833 :group 'mh-letter
1834 :package-version '(MH-E . "8.0"))
1836 (defcustom-mh mh-signature-file-name "~/.signature"
1837 "*Source of user's signature.
1839 By default, the text of your signature is taken from the file
1840 \"~/.signature\". You can read from other sources by changing this
1841 option. This file may contain a vCard in which case an attachment is
1842 added with the vCard.
1844 This option may also be a symbol, in which case that function is
1845 called. You may not want a signature separator to be added for you;
1846 instead you may want to insert one yourself. Options that you may find
1847 useful to do this include `mh-signature-separator' (when inserting a
1848 signature separator) and `mh-signature-separator-regexp' (for finding
1849 said separator). The function `mh-signature-separator-p', which
1850 reports t if the buffer contains a separator, may be useful as well.
1852 The signature is inserted into your message with the command
1853 \\<mh-letter-mode-map>\\[mh-insert-signature] or with the option
1854 `mh-identity-list'."
1855 :type 'file
1856 :group 'mh-letter
1857 :package-version '(MH-E . "6.0"))
1859 (defcustom-mh mh-signature-separator-flag t
1860 "*Non-nil means a signature separator should be inserted.
1862 It is not recommended that you change this option since various
1863 mail user agents, including MH-E, use the separator to present
1864 the signature differently, and to suppress the signature when
1865 replying or yanking a letter into a draft."
1866 :type 'boolean
1867 :group 'mh-letter
1868 :package-version '(MH-E . "8.0"))
1870 (defcustom-mh mh-x-face-file "~/.face"
1871 "*File containing face header field to insert in outgoing mail.
1873 If the file starts with either of the strings \"X-Face:\", \"Face:\"
1874 or \"X-Image-URL:\" then the contents are added to the message header
1875 verbatim. Otherwise it is assumed that the file contains the value of
1876 the \"X-Face:\" header field.
1878 The \"X-Face:\" header field, which is a low-resolution, black and
1879 white image, can be generated using the \"compface\" command (see URL
1880 `ftp://ftp.cs.indiana.edu/pub/faces/compface/compface.tar.Z'). The
1881 \"Online X-Face Converter\" is a useful resource for quick conversion
1882 of images into \"X-Face:\" header fields (see URL
1883 `http://www.dairiki.org/xface/').
1885 Use the \"make-face\" script to convert a JPEG image to the higher
1886 resolution, color, \"Face:\" header field (see URL
1887 `http://quimby.gnus.org/circus/face/make-face').
1889 The URL of any image can be used for the \"X-Image-URL:\" field and no
1890 processing of the image is required.
1892 To prevent the setting of any of these header fields, either set
1893 `mh-x-face-file' to nil, or simply ensure that the file defined by
1894 this option doesn't exist."
1895 :type 'file
1896 :group 'mh-letter
1897 :package-version '(MH-E . "7.0"))
1899 (defcustom-mh mh-yank-behavior 'attribution
1900 "*Controls which part of a message is yanked by \\<mh-letter-mode-map>\\[mh-yank-cur-msg].
1902 To include the entire message, including the entire header, use
1903 \"Body and Header\". Use \"Body\" to yank just the body without
1904 the header. To yank only the portion of the message following the
1905 point, set this option to \"Below Point\".
1907 Choose \"Invoke supercite\" to pass the entire message and header
1908 through supercite.
1910 If the \"Body With Attribution\" setting is used, then the
1911 message minus the header is yanked and a simple attribution line
1912 is added at the top using the value of the option
1913 `mh-extract-from-attribution-verb'. This is the default.
1915 If the \"Invoke supercite\" or \"Body With Attribution\" settings
1916 are used, the \"-noformat\" argument is passed to the \"repl\"
1917 program to override a \"-filter\" or \"-format\" argument. These
1918 settings also have \"Automatically\" variants that perform the
1919 action automatically when you reply so that you don't need to use
1920 \\[mh-yank-cur-msg] at all. Note that this automatic action is
1921 only performed if the show buffer matches the message being
1922 replied to. People who use the automatic variants tend to turn on
1923 the option `mh-delete-yanked-msg-window-flag' as well so that the
1924 show window is never displayed.
1926 If the show buffer has a region, the option `mh-yank-behavior' is
1927 ignored unless its value is one of Attribution variants in which
1928 case the attribution is added to the yanked region.
1930 If this option is set to one of the supercite flavors, the hook
1931 `mail-citation-hook' is ignored and `mh-ins-buf-prefix' is not
1932 inserted."
1933 :type '(choice (const :tag "Body and Header" t)
1934 (const :tag "Body" body)
1935 (const :tag "Below Point" nil)
1936 (const :tag "Invoke supercite" supercite)
1937 (const :tag "Invoke supercite, Automatically" autosupercite)
1938 (const :tag "Body With Attribution" attribution)
1939 (const :tag "Body With Attribution, Automatically"
1940 autoattrib))
1941 :group 'mh-letter
1942 :package-version '(MH-E . "8.0"))
1944 ;;; Ranges (:group 'mh-ranges)
1946 (defcustom-mh mh-interpret-number-as-range-flag t
1947 "*Non-nil means interpret a number as a range.
1949 Since one of the most frequent ranges used is \"last:N\", MH-E
1950 will interpret input such as \"200\" as \"last:200\" if this
1951 option is on (which is the default). If you need to scan just the
1952 message 200, then use the range \"200:200\"."
1953 :type 'boolean
1954 :group 'mh-ranges
1955 :package-version '(MH-E . "7.4"))
1957 ;;; Scan Line Formats (:group 'mh-scan-line-formats)
1959 (eval-and-compile
1960 (unless (fboundp 'mh-adaptive-cmd-note-flag-check)
1961 (defun mh-adaptive-cmd-note-flag-check (symbol value)
1962 "Temporary definition.
1963 Real definition, below, uses variables that aren't defined yet."
1964 (set-default symbol value))))
1966 (defcustom-mh mh-adaptive-cmd-note-flag t
1967 "*Non-nil means that the message number width is determined dynamically.
1969 If you've created your own format to handle long message numbers,
1970 you'll be pleased to know you no longer need it since MH-E adapts its
1971 internal format based upon the largest message number if this option
1972 is on (the default). This option may only be turned on when
1973 `mh-scan-format-file' is set to \"Use MH-E scan Format\".
1975 If you prefer fixed-width message numbers, turn off this option and
1976 call `mh-set-cmd-note' with the width specified by your format file
1977 \(see `mh-scan-format-file'). For example, the default width is 4, so
1978 you would use \"(mh-set-cmd-note 4)\"."
1979 :type 'boolean
1980 :group 'mh-scan-line-formats
1981 :set 'mh-adaptive-cmd-note-flag-check
1982 :package-version '(MH-E . "7.0"))
1984 (defun mh-scan-format-file-check (symbol value)
1985 "Check if desired setting is legal.
1986 Throw an error if user tries to set `mh-scan-format-file' to
1987 anything but t when `mh-adaptive-cmd-note-flag' is on. Otherwise,
1988 set SYMBOL to VALUE."
1989 (if (and (not (eq value t))
1990 mh-adaptive-cmd-note-flag)
1991 (error "%s %s" "You must turn off `mh-adaptive-cmd-note-flag'"
1992 "unless you use \"Use MH-E scan Format\"")
1993 (set-default symbol value)))
1995 (defcustom-mh mh-scan-format-file t
1996 "Specifies the format file to pass to the scan program.
1998 The default setting for this option is \"Use MH-E scan Format\". This
1999 means that the format string will be taken from the either
2000 `mh-scan-format-mh' or `mh-scan-format-nmh' depending on whether MH or
2001 nmh (or GNU mailutils) is in use. This setting also enables you to
2002 turn on the `mh-adaptive-cmd-note-flag' option.
2004 You can also set this option to \"Use Default scan Format\" to get the
2005 same output as you would get if you ran \"scan\" from the shell. If
2006 you have a format file that you want MH-E to use but not MH, you can
2007 set this option to \"Specify a scan Format File\" and enter the name
2008 of your format file.
2010 If you change the format of the scan lines you'll need to tell MH-E
2011 how to parse the new format. As you will see, quite a lot of variables
2012 are involved to do that. Use \"\\[apropos] RET mh-scan.*regexp\" to
2013 obtain a list of these variables. You will also have to call
2014 `mh-set-cmd-note' if your notations are not in column 4 (columns in
2015 Emacs start with 0)."
2016 :type '(choice (const :tag "Use MH-E scan Format" t)
2017 (const :tag "Use Default scan Format" nil)
2018 (file :tag "Specify a scan Format File"))
2019 :group 'mh-scan-line-formats
2020 :set 'mh-scan-format-file-check
2021 :package-version '(MH-E . "6.0"))
2023 (defun mh-adaptive-cmd-note-flag-check (symbol value)
2024 "Check if desired setting is legal.
2025 Throw an error if user tries to turn on
2026 `mh-adaptive-cmd-note-flag' when `mh-scan-format-file' isn't t.
2027 Otherwise, set SYMBOL to VALUE."
2028 (if (and value
2029 (not (eq mh-scan-format-file t)))
2030 (error "%s %s" "Can't turn on unless `mh-scan-format-file'"
2031 "is set to \"Use MH-E scan Format\"")
2032 (set-default symbol value)))
2034 (defcustom-mh mh-scan-prog "scan"
2035 "*Program used to scan messages.
2037 The name of the program that generates a listing of one line per
2038 message is held in this option. Unless this variable contains an
2039 absolute pathname, it is assumed to be in the `mh-progs'
2040 directory. You may link another program to `scan' (see
2041 \"mh-profile(5)\") to produce a different type of listing."
2042 :type 'string
2043 :group 'mh-scan-line-formats
2044 :package-version '(MH-E . "6.0"))
2045 (make-variable-buffer-local 'mh-scan-prog)
2047 ;;; Searching (:group 'mh-search)
2049 (defcustom-mh mh-search-program nil
2050 "Search program that MH-E shall use.
2052 The default setting of this option is \"Auto-detect\" which means
2053 that MH-E will automatically choose one of swish++, swish-e,
2054 mairix, namazu, pick and grep in that order. If, for example, you
2055 have both swish++ and mairix installed and you want to use
2056 mairix, then you can set this option to \"mairix\".
2058 More information about setting up an indexing program to use with
2059 MH-E can be found in the documentation of `mh-search'."
2060 :type '(choice (const :tag "Auto-detect" nil)
2061 (const :tag "swish++" swish++)
2062 (const :tag "swish-e" swish)
2063 (const :tag "mairix" mairix)
2064 (const :tag "namazu" namazu)
2065 (const :tag "pick" pick)
2066 (const :tag "grep" grep))
2067 :group 'mh-search
2068 :package-version '(MH-E . "8.0"))
2070 ;;; Sending Mail (:group 'mh-sending-mail)
2072 (defcustom-mh mh-compose-forward-as-mime-flag t
2073 "*Non-nil means that messages are forwarded as attachments.
2075 By default, this option is on which means that the forwarded
2076 messages are included as attachments. If you would prefer to
2077 forward your messages verbatim (as text, inline), then turn off
2078 this option. Forwarding messages verbatim works well for short,
2079 textual messages, but your recipient won't be able to view any
2080 non-textual attachments that were in the forwarded message. Be
2081 aware that if you have \"forw: -mime\" in your MH profile, then
2082 forwarded messages will always be included as attachments
2083 regardless of the settings of this option."
2084 :type 'boolean
2085 :group 'mh-sending-mail
2086 :package-version '(MH-E . "8.0"))
2088 (defcustom-mh mh-compose-letter-function nil
2089 "Invoked when starting a new draft.
2091 However, it is the last function called before you edit your
2092 message. The consequence of this is that you can write a function
2093 to write and send the message for you. This function is passed
2094 three arguments: the contents of the TO, SUBJECT, and CC header
2095 fields."
2096 :type '(choice (const nil) function)
2097 :group 'mh-sending-mail
2098 :package-version '(MH-E . "6.0"))
2100 (defcustom-mh mh-compose-prompt-flag nil
2101 "*Non-nil means prompt for header fields when composing a new draft."
2102 :type 'boolean
2103 :group 'mh-sending-mail
2104 :package-version '(MH-E . "7.4"))
2106 (defcustom-mh mh-forward-subject-format "%s: %s"
2107 "*Format string for forwarded message subject.
2109 This option is a string which includes two escapes (\"%s\"). The
2110 first \"%s\" is replaced with the sender of the original message,
2111 and the second one is replaced with the original \"Subject:\"."
2112 :type 'string
2113 :group 'mh-sending-mail
2114 :package-version '(MH-E . "6.0"))
2116 (defcustom-mh mh-insert-x-mailer-flag t
2117 "*Non-nil means append an \"X-Mailer:\" header field to the header.
2119 This header field includes the version of MH-E and Emacs that you
2120 are using. If you don't want to participate in our marketing, you
2121 can turn this option off."
2122 :type 'boolean
2123 :group 'mh-sending-mail
2124 :package-version '(MH-E . "7.0"))
2126 (defcustom-mh mh-redist-full-contents-flag nil
2127 "*Non-nil means the \"dist\" command needs entire letter for redistribution.
2129 This option must be turned on if \"dist\" requires the whole
2130 letter for redistribution, which is the case if \"send\" is
2131 compiled with the BERK option (which many people abhor). If you
2132 find that MH will not allow you to redistribute a message that
2133 has been redistributed before, turn off this option."
2134 :type 'boolean
2135 :group 'mh-sending-mail
2136 :package-version '(MH-E . "8.0"))
2138 (defcustom-mh mh-reply-default-reply-to nil
2139 "*Sets the person or persons to whom a reply will be sent.
2141 This option is set to \"Prompt\" by default so that you are
2142 prompted for the recipient of a reply. If you find that most of
2143 the time that you specify \"cc\" when you reply to a message, set
2144 this option to \"cc\". Other choices include \"from\", \"to\", or
2145 \"all\". You can always edit the recipients in the draft."
2146 :type '(choice (const :tag "Prompt" nil)
2147 (const "from")
2148 (const "to")
2149 (const "cc")
2150 (const "all"))
2151 :group 'mh-sending-mail
2152 :package-version '(MH-E . "6.0"))
2154 (defcustom-mh mh-reply-show-message-flag t
2155 "*Non-nil means the MH-Show buffer is displayed when replying.
2157 If you include the message automatically, you can hide the
2158 MH-Show buffer by turning off this option.
2160 See also `mh-reply'."
2161 :type 'boolean
2162 :group 'mh-sending-mail
2163 :package-version '(MH-E . "7.0"))
2165 ;;; Sequences (:group 'mh-sequences)
2167 ;; If `mh-unpropagated-sequences' becomes a defcustom, add the following to
2168 ;; the docstring: "Additional sequences that should not to be preserved can be
2169 ;; specified by setting `mh-unpropagated-sequences' appropriately." XXX
2171 (defcustom-mh mh-refile-preserves-sequences-flag t
2172 "*Non-nil means that sequences are preserved when messages are refiled.
2174 If a message is in any sequence (except \"Previous-Sequence:\"
2175 and \"cur\") when it is refiled, then it will still be in those
2176 sequences in the destination folder. If this behavior is not
2177 desired, then turn off this option."
2178 :type 'boolean
2179 :group 'mh-sequences
2180 :package-version '(MH-E . "7.4"))
2182 (defcustom-mh mh-tick-seq 'tick
2183 "The name of the MH sequence for ticked messages.
2185 You can customize this option if you already use the \"tick\"
2186 sequence for your own use. You can also disable all of the
2187 ticking functions by choosing the \"Disable Ticking\" item but
2188 there isn't much advantage to that."
2189 :type '(choice (const :tag "Disable Ticking" nil)
2190 symbol)
2191 :group 'mh-sequences
2192 :package-version '(MH-E . "7.3"))
2194 (defcustom-mh mh-update-sequences-after-mh-show-flag t
2195 "*Non-nil means flush MH sequences to disk after message is shown\\<mh-folder-mode-map>.
2197 Three sequences are maintained internally by MH-E and pushed out
2198 to MH when a message is shown. They include the sequence
2199 specified by your \"Unseen-Sequence:\" profile entry, \"cur\",
2200 and the sequence listed by the option `mh-tick-seq' which is
2201 \"tick\" by default. If you do not like this behavior, turn off
2202 this option. You can then update the state manually with the
2203 \\[mh-execute-commands], \\[mh-quit], or \\[mh-update-sequences]
2204 commands."
2205 :type 'boolean
2206 :group 'mh-sequences
2207 :package-version '(MH-E . "7.0"))
2209 ;;; Reading Your Mail (:group 'mh-show)
2211 (defcustom-mh mh-bury-show-buffer-flag t
2212 "*Non-nil means show buffer is buried.
2214 One advantage of not burying the show buffer is that one can
2215 delete the show buffer more easily in an electric buffer list
2216 because of its proximity to its associated MH-Folder buffer. Try
2217 running \\[electric-buffer-list] to see what I mean."
2218 :type 'boolean
2219 :group 'mh-show
2220 :package-version '(MH-E . "7.0"))
2222 (defcustom-mh mh-clean-message-header-flag t
2223 "*Non-nil means remove extraneous header fields.
2225 See also `mh-invisible-header-fields-default' and
2226 `mh-invisible-header-fields'."
2227 :type 'boolean
2228 :group 'mh-show
2229 :package-version '(MH-E . "7.0"))
2231 (defcustom-mh mh-decode-mime-flag (not (not (locate-library "mm-decode")))
2232 "*Non-nil means attachments are handled\\<mh-folder-mode-map>.
2234 MH-E can handle attachments as well if the Gnus `mm-decode'
2235 library is present. If so, this option will be on. Otherwise,
2236 you'll see the MIME body parts rather than text or attachments.
2237 There isn't much point in turning off this option; however, you
2238 can inspect it if it appears that the body parts are not being
2239 interpreted correctly or toggle it with the command
2240 \\[mh-toggle-mh-decode-mime-flag] to view the raw message.
2242 This option also controls the display of quoted-printable
2243 messages and other graphical widgets. See the options
2244 `mh-graphical-smileys-flag' and `mh-graphical-emphasis-flag'."
2245 :type 'boolean
2246 :group 'mh-show
2247 :package-version '(MH-E . "7.0"))
2249 (defcustom-mh mh-display-buttons-for-alternatives-flag nil
2250 "*Non-nil means display buttons for all alternative attachments.
2252 Sometimes, a mail program will produce multiple alternatives of
2253 the attachment in increasing degree of faithfulness to the
2254 original content. By default, only the preferred alternative is
2255 displayed. If this option is on, then the preferred part is shown
2256 inline and buttons are shown for each of the other alternatives."
2257 :type 'boolean
2258 :group 'mh-show
2259 :package-version '(MH-E . "7.4"))
2261 (defcustom-mh mh-display-buttons-for-inline-parts-flag nil
2262 "*Non-nil means display buttons for all inline attachments\\<mh-folder-mode-map>.
2264 The sender can request that attachments should be viewed inline so
2265 that they do not really appear like an attachment at all to the
2266 reader. Most of the time, this is desirable, so by default MH-E
2267 suppresses the buttons for inline attachments. On the other hand, you
2268 may receive code or HTML which the sender has added to his message as
2269 inline attachments so that you can read them in MH-E. In this case, it
2270 is useful to see the buttons so that you know you don't have to cut
2271 and paste the code into a file; you can simply save the attachment.
2273 If you want to make the buttons visible for inline attachments, you
2274 can use the command \\[mh-toggle-mime-buttons] to toggle the
2275 visibility of these buttons. You can turn on these buttons permanently
2276 by turning on this option.
2278 MH-E cannot display all attachments inline however. It can display
2279 text (including HTML) and images."
2280 :type 'boolean
2281 :group 'mh-show
2282 :package-version '(MH-E . "7.0"))
2284 (defcustom-mh mh-do-not-confirm-flag nil
2285 "*Non-nil means non-reversible commands do not prompt for confirmation.
2287 Commands such as `mh-pack-folder' prompt to confirm whether to
2288 process outstanding moves and deletes or not before continuing.
2289 Turning on this option means that these actions will be
2290 performed--which is usually desired but cannot be
2291 retracted--without question."
2292 :type 'boolean
2293 :group 'mh-show
2294 :package-version '(MH-E . "7.0"))
2296 (defcustom-mh mh-fetch-x-image-url nil
2297 "*Control fetching of \"X-Image-URL:\" header field image.
2299 Ths option controls the fetching of the \"X-Image-URL:\" header
2300 field image with the following values:
2302 Ask Before Fetching
2303 You are prompted before the image is fetched. MH-E will
2304 remember your reply and will either use the already fetched
2305 image the next time the same URL is encountered or silently
2306 skip it if you didn't fetch it the first time. This is a
2307 good setting.
2309 Never Fetch
2310 Images are never fetched and only displayed if they are
2311 already present in the cache. This is the default.
2313 There isn't a value of \"Always Fetch\" for privacy and DOS (denial of
2314 service) reasons. For example, fetching a URL can tip off a spammer
2315 that you've read his email (which is why you shouldn't blindly answer
2316 yes if you've set this option to \"Ask Before Fetching\"). Someone may
2317 also flood your network and fill your disk drive by sending a torrent
2318 of messages, each specifying a unique URL to a very large file.
2320 The cache of images is found in the directory \".mhe-x-image-cache\"
2321 within your MH directory. You can add your own face to the \"From:\"
2322 field too. See Info node `(mh-e)Picture'.
2324 This setting only has effect if the option `mh-show-use-xface-flag' is
2325 turned on."
2327 :type '(choice (const :tag "Ask Before Fetching" ask)
2328 (const :tag "Never Fetch" nil))
2329 :group 'mh-show
2330 :package-version '(MH-E . "7.3"))
2332 (defcustom-mh mh-graphical-smileys-flag t
2333 "*Non-nil means graphical smileys are displayed.
2335 It is a long standing custom to inject body language using a
2336 cornucopia of punctuation, also known as the \"smileys\". MH-E
2337 can render these as graphical widgets if this option is turned
2338 on, which it is by default. Smileys include patterns such as :-)
2339 and ;-).
2341 This option is disabled if the option `mh-decode-mime-flag' is
2342 turned off."
2343 :type 'boolean
2344 :group 'mh-show
2345 :package-version '(MH-E . "7.0"))
2347 (defcustom-mh mh-graphical-emphasis-flag t
2348 "*Non-nil means graphical emphasis is displayed.
2350 A few typesetting features are indicated in ASCII text with
2351 certain characters. If your terminal supports it, MH-E can render
2352 these typesetting directives naturally if this option is turned
2353 on, which it is by default. For example, _underline_ will be
2354 underlined, *bold* will appear in bold, /italics/ will appear in
2355 italics, and so on. See the option `gnus-emphasis-alist' for the
2356 whole list.
2358 This option is disabled if the option `mh-decode-mime-flag' is
2359 turned off."
2360 :type 'boolean
2361 :group 'mh-show
2362 :package-version '(MH-E . "7.0"))
2364 (defcustom-mh mh-highlight-citation-style 'gnus
2365 "Style for highlighting citations.
2367 If the sender of the message has cited other messages in his
2368 message, then MH-E will highlight these citations to emphasize
2369 the sender's actual response. This option can be customized to
2370 change the highlighting style. The \"Multicolor\" method uses a
2371 different color for each indentation while the \"Monochrome\"
2372 method highlights all citations in red. To disable highlighting
2373 of citations entirely, choose \"None\"."
2374 :type '(choice (const :tag "Multicolor" gnus)
2375 (const :tag "Monochrome" font-lock)
2376 (const :tag "None" nil))
2377 :group 'mh-show
2378 :package-version '(MH-E . "8.0"))
2380 ;; Theese entries have been intentionally excluded by the developers.
2381 ;; "X-Operator:" ; Similar to X-Mailer, so display it
2382 ;; "Comments:" ; RFC 2822 - show this one
2383 ;; "Fax:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2384 ;; "Mail-System-Version:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2385 ;; "Mailer:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2386 ;; "Phone:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2387 ;; "Reply-By:" ; RFC 2156
2388 ;; "Reply-To:" ; RFC 2822
2389 ;; "User-Agent:" ; Similar to X-Mailer, so display it.
2391 ;; Keep fields alphabetized. Mention source, if known.
2392 (defvar mh-invisible-header-fields-internal
2394 "Abuse-Reports-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2395 "Also-Control:" ; H. Spencer: News Article Format and Transmission, June 1994
2396 "Alternate-recipient:" ; RFC 2156
2397 "Approved-By:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2398 "Approved:" ; RFC 1036
2399 "Article-Names:" ; H. Spencer: News Article Format and Transmission, June 1994
2400 "Article-Updates:" ; H. Spencer: News Article Format and Transmission, June 1994
2401 "Authentication-Results:"
2402 "Auto-forwarded:" ; RFC 2156
2403 "Autoforwarded:" ; RFC 2156
2404 "Bestservhost:"
2405 "Cancel-Key:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2406 "Cancel-Lock:" ; NNTP posts
2407 "Comment:" ; Shows up with DomainKeys
2408 "Content-" ; RFC 2045, 1123, 1766, 1864, 2045, 2110, 2156, 2183, 2912
2409 "Control:" ; RFC 1036
2410 "Conversion-With-Loss:" ; RFC 2156
2411 "Conversion:" ; RFC 2156
2412 "DKIM-" ; http://antispam.yahoo.com/domainkeys
2413 "DL-Expansion-History:" ; RFC 2156
2414 "Delivered-To:" ; Egroups/yahoogroups mailing list manager
2415 "Delivery-Date:" ; RFC 2156
2416 "Delivery:"
2417 "Discarded-X400-" ; RFC 2156
2418 "Disclose-Recipients:" ; RFC 2156
2419 "Disposition-Notification-Options:" ; RFC 2298
2420 "Disposition-Notification-To:" ; RFC 2298
2421 "Distribution:" ; RFC 1036
2422 "DomainKey-" ; http://antispam.yahoo.com/domainkeys
2423 "Encoding:" ; RFC 1505
2424 "Envelope-to:"
2425 "Errors-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2426 "Expires:" ; RFC 1036
2427 "Expiry-Date:" ; RFC 2156
2428 "Face:" ; Gnus Face header
2429 "Followup-To:" ; RFC 1036
2430 "For-Approval:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2431 "For-Comment:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2432 "For-Handdling:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2433 "Forwarded:" ; MH
2434 "From " ; sendmail
2435 "Generate-Delivery-Report:" ; RFC 2156
2436 "Importance:" ; RFC 2156, 2421
2437 "In-Reply-To:" ; RFC 2822
2438 "Incomplete-Copy:" ; RFC 2156
2439 "Keywords:" ; RFC 2822
2440 "Language:" ; RFC 2156
2441 "Lines:" ; RFC 1036
2442 "List-" ; RFC 2369, 2919
2443 "Mail-Copies-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2444 "Mail-Followup-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2445 "Mail-Reply-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2446 "Mail-from:" ; MH
2447 "Mailing-List:" ; Egroups/yahoogroups mailing list manager
2448 "Message-Content:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2449 "Message-Id:" ; RFC 822
2450 "Message-Type:" ; RFC 2156
2451 "Mime-Version" ; RFC 2045
2452 "NNTP-" ; News
2453 "Newsgroups:" ; RFC 1036
2454 "Obsoletes:" ; RFC 2156
2455 "Old-Return-Path:"
2456 "OpenPGP:"
2457 "Original-Encoded-Information-Types:" ; RFC 2156
2458 "Original-Lines:" ; mail to news
2459 "Original-NNTP-" ; mail to news
2460 "Original-Newsgroups:" ; mail to news
2461 "Original-Path:" ; mail to news
2462 "Original-Received:" ; mail to news
2463 "Original-Recipt:" ; RFC 2298
2464 "Original-To:" ; mail to news
2465 "Original-X-" ; mail to news
2466 "Origination-Client:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2467 "Originator:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2468 "P1-Content-Type:" ; X400
2469 "P1-Message-Id:" ; X400
2470 "P1-Recipient:" ; X400
2471 "Path:" ; RFC 1036
2472 "Pics-Label:" ; W3C
2473 "Posted-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2474 "Precedence:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2475 "Prev-Resent" ; MH
2476 "Prevent-NonDelivery-Report:" ; RFC 2156
2477 "Priority:" ; RFC 2156
2478 "Read-Receipt-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2479 "Received-SPF:" ; Gmail
2480 "Received:" ; RFC 822
2481 "References:" ; RFC 2822
2482 "Registered-Mail-Reply-Requested-By:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2483 "Remailed-" ; MH
2484 "Replaces:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2485 "Replied:" ; MH
2486 "Resent-" ; RFC 2822
2487 "Return-Path:" ; RFC 822
2488 "Return-Receipt-Requested:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2489 "Return-Receipt-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2490 "See-Also:" ; H. Spencer: News Article Format and Transmission, June 1994
2491 "Sensitivity:" ; RFC 2156, 2421
2492 "Speach-Act:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2493 "Status:" ; sendmail
2494 "Supersedes:" ; H. Spencer: News Article Format and Transmission, June 1994
2495 "Telefax:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2496 "Thread-"
2497 "Translated-By:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2498 "Translation-Of:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2499 "Ua-Content-Id:" ; X400
2500 "Via:" ; MH
2501 "X-AMAZON" ; Amazon.com
2502 "X-AOL-IP:" ; AOL WebMail
2503 "X-Abuse-Info:"
2504 "X-Abuse-and-DMCA-"
2505 "X-Accept-Language:"
2506 "X-Accept-Language:" ; Netscape/Mozilla
2507 "X-Ack:"
2508 "X-Admin:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2509 "X-Administrivia-To:"
2510 "X-AntiAbuse:" ; cPanel
2511 "X-Antivirus-Scanner:"
2512 "X-Apparently-From:" ; MS Outlook
2513 "X-Apparently-To:" ; Egroups/yahoogroups mailing list manager
2514 "X-Attribution:"
2515 "X-AuditID:"
2516 "X-Authenticated-Info:" ; Verizon.net?
2517 "X-Authenticated-Sender:" ; AT&T Message Center (webmail)
2518 "X-Authentication-Warning:" ; sendmail
2519 "X-Barracuda-" ; Barracuda spam scores
2520 "X-Beenthere:" ; Mailman mailing list manager
2521 "X-Bigfish:"
2522 "X-Bogosity:" ; bogofilter
2523 "X-Brightmail-Tracker:" ; Brightmail
2524 "X-BrightmailFiltered:" ; Brightmail
2525 "X-Bugzilla-" ; Bugzilla
2526 "X-Comment:" ; AT&T Mailennium
2527 "X-Complaints-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2528 "X-Confirm-Reading-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2529 "X-ContentStamp:" ; NetZero
2530 "X-Cr-Hashedpuzzle:"
2531 "X-Cr-Puzzleid:"
2532 "X-Cron-Env:"
2533 "X-DMCA"
2534 "X-Delivered"
2535 "X-EFL-Spamscore:" ; MIT alumni spam filtering
2536 "X-ELNK-Trace:" ; Earthlink mailer
2537 "X-Enigmail-Version:"
2538 "X-Envelope-Date:" ; GNU mailutils
2539 "X-Envelope-From:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2540 "X-Envelope-Sender:"
2541 "X-Envelope-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2542 "X-EviteMessageId:" ; evite.com
2543 "X-Evolution:" ; Evolution mail client
2544 "X-ExtLoop"
2545 "X-Face:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2546 "X-Folder:" ; Spam
2547 "X-From-Line"
2548 "X-Gmail-" ; Gmail
2549 "X-Gnus-Mail-Source:" ; gnus
2550 "X-Google-" ; Google mail
2551 "X-Greylist:" ; milter-greylist-1.2.1
2552 "X-HTTP-UserAgent:"
2553 "X-Habeas-SWE-" ; Spam
2554 "X-Hashcash:" ; hashcash
2555 "X-IMAP:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2556 "X-Image-URL:"
2557 "X-Info:" ; NTMail
2558 "X-IronPort-" ; IronPort AV
2559 "X-Juno-" ; Juno
2560 "X-List-Host:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2561 "X-List-Subscribe:" ; Unknown mailing list managers
2562 "X-List-Unsubscribe:" ; Unknown mailing list managers
2563 "X-Listprocessor-" ; ListProc(tm) by CREN
2564 "X-Listserver:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2565 "X-Loop:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2566 "X-Lrde-Mailscanner:"
2567 "X-Lumos-SenderID:" ; Roving ConstantContact
2568 "X-MAIL-INFO:" ; NetZero
2569 "X-MB-Message-" ; AOL WebMail
2570 "X-MHE-Checksum:" ; Checksum added during index search
2571 "X-MIME-Autoconverted:" ; sendmail
2572 "X-MIMEOLE:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/sendmail
2573 "X-MIMETrack:"
2574 "X-MS-" ; MS Outlook
2575 "X-MSMail-Priority" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2576 "X-Mail-from:" ; fastmail.fm
2577 "X-MailScanner" ; ListProc(tm) by CREN
2578 "X-Mailing-List:" ; Unknown mailing list managers
2579 "X-Mailman-Approved-At:" ; Mailman mailing list manager
2580 "X-Mailman-Version:" ; Mailman mailing list manager
2581 "X-Mailutils-Message-Id" ; GNU Mailutils
2582 "X-Majordomo:" ; Majordomo mailing list manager
2583 "X-Message-Id"
2584 "X-MessageWall-Score:" ; Unknown mailing list manager, AUC TeX
2585 "X-MimeOLE:" ; MS Outlook
2586 "X-Mms-" ; T-Mobile pictures
2587 "X-Mozilla-Status:" ; Netscape/Mozilla
2588 "X-Msmail-" ; MS Outlook
2589 "X-NAI-Spam-" ; Network Associates Inc. SpamKiller
2590 "X-News:" ; News
2591 "X-Newsreader:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2592 "X-No-Archive:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2593 "X-Notes-Item:" ; Lotus Notes Domino structured header
2594 "X-OperatingSystem:"
2595 "X-Orcl-Content-Type:"
2596 "X-Original-Arrival-Type:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2597 "X-Original-Complaints-To:"
2598 "X-Original-Date:" ; SourceForge mailing list manager
2599 "X-Original-To:"
2600 "X-Original-Trace:"
2601 "X-OriginalArrivalTime:" ; Hotmail
2602 "X-Originating-Email:" ; Hotmail
2603 "X-Originating-IP:" ; Hotmail
2604 "X-PMG-"
2605 "X-Postfilter:"
2606 "X-Priority:" ; MS Outlook
2607 "X-Provags-ID:"
2608 "X-Qotd-" ; User added
2609 "X-RCPT-TO:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2610 "X-RM"
2611 "X-Received-Date:"
2612 "X-Received:"
2613 "X-Report-Abuse-To:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2614 "X-Request-"
2615 "X-Resolved-to:" ; fastmail.fm
2616 "X-Return-Path-Hint:" ; Roving ConstantContact
2617 "X-RocketYMMF:" ; Yahoo
2618 "X-Roving-" ; Roving ConstantContact
2619 "X-SA-Exim-" ; Exim SpamAssassin
2620 "X-SBClass:" ; Spam
2621 "X-SBNote:" ; Spam
2622 "X-SBPass:" ; Spam
2623 "X-SBRule:" ; Spam
2624 "X-SMTP-"
2625 "X-Sasl-enc:" ; Apple Mail
2626 "X-Scanned-By:"
2627 "X-Sender:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2628 "X-Server-Date:"
2629 "X-Server-Uuid:"
2630 "X-Sieve:" ; Sieve filtering
2631 "X-Source"
2632 "X-Spam-" ; Spamassassin
2633 "X-SpamBouncer:" ; Spam
2634 "X-Status"
2635 "X-Submissions-To:"
2636 "X-Telecom-Digest"
2637 "X-Trace:"
2638 "X-UID"
2639 "X-UIDL:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2640 "X-UNTD-" ; NetZero
2641 "X-URI:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2642 "X-URL:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2643 "X-USANET-" ; usa.net
2644 "X-Unity"
2645 "X-UserInfo1:"
2646 "X-VSMLoop:" ; NTMail
2647 "X-Virus-" ;
2648 "X-Vms-To:"
2649 "X-WebTV-Signature:"
2650 "X-Wss-Id:" ; Worldtalk gateways
2651 "X-X-Sender:" ; http://people.dsv.su.se/~jpalme/ietf/mail-headers/
2652 "X-YMail-"
2653 "X-Yahoo"
2654 "X-eGroups-" ; Egroups/yahoogroups mailing list manager
2655 "X-pgp:"
2656 "X-submission-address:"
2657 "X400-" ; X400
2658 "Xref:" ; RFC 1036
2660 "List of default header fields that are not to be shown.
2662 Do not alter this variable directly. Instead, add entries from
2663 here that you would like to be displayed in
2664 `mh-invisible-header-fields-default' and add entries to hide in
2665 `mh-invisible-header-fields'.")
2667 (eval-and-compile
2668 (unless (fboundp 'mh-invisible-headers)
2669 (defun mh-invisible-headers ()
2670 "Temporary definition.
2671 Real definition, below, uses variables that aren't defined yet."
2672 nil)))
2674 (defvar mh-delay-invisible-header-generation-flag t
2675 "Non-nil means to delay the generation of invisible header fields.
2676 Because the function `mh-invisible-headers' uses both
2677 `mh-invisible-header-fields' and `mh-invisible-header-fields', it
2678 cannot be run until both variables have been initialized.")
2680 (defcustom-mh mh-invisible-header-fields nil
2681 "*Additional header fields to hide.
2683 Header fields that you would like to hide that aren't listed in
2684 `mh-invisible-header-fields-default' can be added to this option
2685 with a couple of caveats. Regular expressions are not allowed.
2686 Unique fields should have a \":\" suffix; otherwise, the element
2687 can be used to render invisible an entire class of fields that
2688 start with the same prefix. If you think a header field should be
2689 generally ignored, report a bug (see URL
2690 `https://sourceforge.net/tracker/?group_id=13357&atid=113357').
2692 See also `mh-clean-message-header-flag'."
2694 :type '(repeat (string :tag "Header field"))
2695 :set (lambda (symbol value)
2696 (set-default symbol value)
2697 (mh-invisible-headers))
2698 :group 'mh-show
2699 :package-version '(MH-E . "7.1"))
2701 (defcustom-mh mh-invisible-header-fields-default nil
2702 "*List of hidden header fields.
2704 The header fields listed in this option are hidden, although you
2705 can check off any field that you would like to see.
2707 Header fields that you would like to hide that aren't listed can
2708 be added to the option `mh-invisible-header-fields'.
2710 See also `mh-clean-message-header-flag'."
2711 :type `(set ,@(mapcar (lambda (x) `(const ,x))
2712 mh-invisible-header-fields-internal))
2713 :set (lambda (symbol value)
2714 (set-default symbol value)
2715 (mh-invisible-headers))
2716 :group 'mh-show
2717 :package-version '(MH-E . "8.0"))
2719 (defvar mh-invisible-header-fields-compiled nil
2720 "*Regexp matching lines in a message header that are not to be shown.
2721 Do not alter this variable directly. Instead, customize
2722 `mh-invisible-header-fields-default' checking for fields normally
2723 hidden that you wish to display, and add extra entries to hide in
2724 `mh-invisible-header-fields'.")
2726 (defun mh-invisible-headers ()
2727 "Make or remake the variable `mh-invisible-header-fields-compiled'.
2728 Done using `mh-invisible-header-fields-internal' as input, from
2729 which entries from `mh-invisible-header-fields-default' are
2730 removed and entries from `mh-invisible-header-fields' are added."
2731 (let ((fields mh-invisible-header-fields-internal))
2732 (when mh-invisible-header-fields-default
2733 ;; Remove entries from `mh-invisible-header-fields-default'
2734 (setq fields
2735 (loop for x in fields
2736 unless (member x mh-invisible-header-fields-default)
2737 collect x)))
2738 (when (and (boundp 'mh-invisible-header-fields)
2739 mh-invisible-header-fields)
2740 (dolist (x mh-invisible-header-fields)
2741 (unless (member x fields) (setq fields (cons x fields)))))
2742 (if fields
2743 (setq mh-invisible-header-fields-compiled
2744 (concat
2746 ;; workaround for insufficient default
2747 (let ((max-specpdl-size 1000))
2748 (regexp-opt fields t))))
2749 (setq mh-invisible-header-fields-compiled nil))))
2751 ;; Compile invisible header fields.
2752 (mh-invisible-headers)
2754 (defcustom-mh mh-lpr-command-format "lpr -J '%s'"
2755 "*Command used to print\\<mh-folder-mode-map>.
2757 This option contains the Unix command line which performs the
2758 actual printing for the \\[mh-print-msg] command. The string can
2759 contain one escape, \"%s\", which is replaced by the name of the
2760 folder and the message number and is useful for print job names.
2761 I use \"mpage -h'%s' -b Letter -H1of -mlrtb -P\" which produces a
2762 nice header and adds a bit of margin so the text fits within my
2763 printer's margins.
2765 This options is not used by the commands \\[mh-ps-print-msg] or
2766 \\[mh-ps-print-msg-file]."
2767 :type 'string
2768 :group 'mh-show
2769 :package-version '(MH-E . "6.0"))
2771 (defcustom-mh mh-max-inline-image-height nil
2772 "*Maximum inline image height if \"Content-Disposition:\" is not present.
2774 Some older mail programs do not insert this needed plumbing to
2775 tell MH-E whether to display the attachments inline or not. If
2776 this is the case, MH-E will display these images inline if they
2777 are smaller than the window. However, you might want to allow
2778 larger images to be displayed inline. To do this, you can change
2779 the options `mh-max-inline-image-width' and
2780 `mh-max-inline-image-height' from their default value of zero to
2781 a large number. The size of your screen is a good choice for
2782 these numbers."
2783 :type '(choice (const nil) integer)
2784 :group 'mh-show
2785 :package-version '(MH-E . "7.0"))
2787 (defcustom-mh mh-max-inline-image-width nil
2788 "*Maximum inline image width if \"Content-Disposition:\" is not present.
2790 Some older mail programs do not insert this needed plumbing to
2791 tell MH-E whether to display the attachments inline or not. If
2792 this is the case, MH-E will display these images inline if they
2793 are smaller than the window. However, you might want to allow
2794 larger images to be displayed inline. To do this, you can change
2795 the options `mh-max-inline-image-width' and
2796 `mh-max-inline-image-height' from their default value of zero to
2797 a large number. The size of your screen is a good choice for
2798 these numbers."
2799 :type '(choice (const nil) integer)
2800 :group 'mh-show
2801 :package-version '(MH-E . "7.0"))
2803 (defcustom-mh mh-mhl-format-file nil
2804 "*Specifies the format file to pass to the \"mhl\" program.
2806 Normally MH-E takes care of displaying messages itself (rather than
2807 calling an MH program to do the work). If you'd rather have \"mhl\"
2808 display the message (within MH-E), change this option from its default
2809 value of \"Use Default mhl Format (Printing Only)\".
2811 You can set this option to \"Use Default mhl Format\" to get the same
2812 output as you would get if you ran \"mhl\" from the shell.
2814 If you have a format file that you want MH-E to use, you can set this
2815 option to \"Specify an mhl Format File\" and enter the name of your
2816 format file. Your format file should specify a non-zero value for
2817 \"overflowoffset\" to allow MH-E to parse the header. Note that
2818 \"mhl\" is always used for printing and forwarding; in this case, the
2819 value of this option is consulted if you have specified a format
2820 file."
2821 :type '(choice (const :tag "Use Default mhl Format (Printing Only)" nil)
2822 (const :tag "Use Default mhl Format" t)
2823 (file :tag "Specify an mhl Format File"))
2824 :group 'mh-show
2825 :package-version '(MH-E . "8.0"))
2827 (defcustom-mh mh-mime-save-parts-default-directory t
2828 "Default directory to use for \\<mh-folder-mode-map>\\[mh-mime-save-parts].
2830 The default value for this option is \"Prompt Always\" so that
2831 you are always prompted for the directory in which to save the
2832 attachments. However, if you usually use the same directory
2833 within a session, then you can set this option to \"Prompt the
2834 First Time\" to avoid the prompt each time. you can make this
2835 directory permanent by choosing \"Directory\" and entering the
2836 directory's name."
2837 :type '(choice (const :tag "Prompt the First Time" nil)
2838 (const :tag "Prompt Always" t)
2839 directory)
2840 :group 'mh-show
2841 :package-version '(MH-E . "7.0"))
2843 (defcustom-mh mh-print-background-flag nil
2844 "*Non-nil means messages should be printed in the background\\<mh-folder-mode-map>.
2846 Normally messages are printed in the foreground. If this is slow on
2847 your system, you may elect to turn off this option to print in the
2848 background.
2850 WARNING: If you do this, do not delete the message until it is printed
2851 or else the output may be truncated.
2853 This option is not used by the commands \\[mh-ps-print-msg] or
2854 \\[mh-ps-print-msg-file]."
2855 :type 'boolean
2856 :group 'mh-show
2857 :package-version '(MH-E . "7.0"))
2859 (defcustom-mh mh-show-maximum-size 0
2860 "*Maximum size of message (in bytes) to display automatically.
2862 This option provides an opportunity to skip over large messages
2863 which may be slow to load. The default value of 0 means that all
2864 message are shown regardless of size."
2865 :type 'integer
2866 :group 'mh-show
2867 :package-version '(MH-E . "8.0"))
2869 (defcustom-mh mh-show-use-xface-flag (>= emacs-major-version 21)
2870 "*Non-nil means display face images in MH-show buffers.
2872 MH-E can display the content of \"Face:\", \"X-Face:\", and
2873 \"X-Image-URL:\" header fields. If any of these fields occur in the
2874 header of your message, the sender's face will appear in the \"From:\"
2875 header field. If more than one of these fields appear, then the first
2876 field found in the order \"Face:\", \"X-Face:\", and \"X-Image-URL:\"
2877 will be used.
2879 The option `mh-show-use-xface-flag' is used to turn this feature on
2880 and off. This feature will be turned on by default if your system
2881 supports it.
2883 The first header field used, if present, is the Gnus-specific
2884 \"Face:\" field. The \"Face:\" field appeared in GNU Emacs 21 and
2885 XEmacs. For more information, see URL
2886 `http://quimby.gnus.org/circus/face/'. Next is the traditional
2887 \"X-Face:\" header field. The display of this field requires the
2888 \"uncompface\" program (see URL
2889 `ftp://ftp.cs.indiana.edu/pub/faces/compface/compface.tar.z'). Recent
2890 versions of XEmacs have internal support for \"X-Face:\" images. If
2891 your version of XEmacs does not, then you'll need both \"uncompface\"
2892 and the x-face package (see URL `ftp://ftp.jpl.org/pub/elisp/').
2894 Finally, MH-E will display images referenced by the \"X-Image-URL:\"
2895 header field if neither the \"Face:\" nor the \"X-Face:\" fields are
2896 present. The display of the images requires \"wget\" (see URL
2897 `http://www.gnu.org/software/wget/wget.html'), \"fetch\", or \"curl\"
2898 to fetch the image and the \"convert\" program from the ImageMagick
2899 suite (see URL `http://www.imagemagick.org/'). Of the three header
2900 fields this is the most efficient in terms of network usage since the
2901 image doesn't need to be transmitted with every single mail.
2903 The option `mh-fetch-x-image-url' controls the fetching of the
2904 \"X-Image-URL:\" header field image."
2905 :type 'boolean
2906 :group 'mh-show
2907 :package-version '(MH-E . "7.0"))
2909 (defcustom-mh mh-store-default-directory nil
2910 "*Default directory for \\<mh-folder-mode-map>\\[mh-store-msg].
2912 If you would like to change the initial default directory,
2913 customize this option, change the value from \"Current\" to
2914 \"Directory\", and then enter the name of the directory for storing
2915 the content of these messages."
2916 :type '(choice (const :tag "Current" nil)
2917 directory)
2918 :group 'mh-show
2919 :package-version '(MH-E . "6.0"))
2921 (defcustom-mh mh-summary-height nil
2922 "*Number of lines in MH-Folder buffer (including the mode line).
2924 The default value of this option is \"Automatic\" which means
2925 that the MH-Folder buffer will maintain the same proportional
2926 size if the frame is resized. If you'd prefer a fixed height,
2927 then choose the \"Fixed Size\" option and enter the number of
2928 lines you'd like to see."
2929 :type '(choice (const :tag "Automatic" nil)
2930 (integer :tag "Fixed Size"))
2931 :group 'mh-show
2932 :package-version '(MH-E . "7.4"))
2934 ;;; The Speedbar (:group 'mh-speedbar)
2936 (defcustom-mh mh-speed-update-interval 60
2937 "Time between speedbar updates in seconds.
2938 Set to 0 to disable automatic update."
2939 :type 'integer
2940 :group 'mh-speedbar
2941 :package-version '(MH-E . "8.0"))
2943 ;;; Threading (:group 'mh-thread)
2945 (defcustom-mh mh-show-threads-flag nil
2946 "*Non-nil means new folders start in threaded mode.
2948 Threading large number of messages can be time consuming so this
2949 option is turned off by default. If you turn this option on, then
2950 threading will be done only if the number of messages being
2951 threaded is less than `mh-large-folder'."
2952 :type 'boolean
2953 :group 'mh-thread
2954 :package-version '(MH-E . "7.1"))
2956 ;;; The Tool Bar (:group 'mh-tool-bar)
2958 ;; mh-tool-bar-folder-buttons and mh-tool-bar-letter-buttons defined
2959 ;; dynamically in mh-tool-bar.el.
2961 (defcustom-mh mh-tool-bar-search-function 'mh-search
2962 "*Function called by the tool bar search button.
2964 By default, this is set to `mh-search'. You can also choose
2965 \"Other Function\" from the \"Value Menu\" and enter a function
2966 of your own choosing."
2967 :type '(choice (const mh-search)
2968 (function :tag "Other Function"))
2969 :group 'mh-tool-bar
2970 :package-version '(MH-E . "7.0"))
2972 ;; XEmacs has a couple of extra customizations...
2973 (mh-do-in-xemacs
2974 (defcustom-mh mh-xemacs-use-tool-bar-flag mh-xemacs-has-tool-bar-flag
2975 "*If non-nil, use tool bar.
2977 This option controls whether to show the MH-E icons at all. By
2978 default, this option is turned on if the window system supports
2979 tool bars. If your system doesn't support tool bars, then you
2980 won't be able to turn on this option."
2981 :type 'boolean
2982 :group 'mh-tool-bar
2983 :set (lambda (symbol value)
2984 (if (and (eq value t)
2985 (not mh-xemacs-has-tool-bar-flag))
2986 (error "Tool bar not supported"))
2987 (set-default symbol value))
2988 :package-version '(MH-E . "7.3"))
2990 (defcustom-mh mh-xemacs-tool-bar-position nil
2991 "*Tool bar location.
2993 This option controls the placement of the tool bar along the four
2994 edges of the frame. You can choose from one of \"Same As Default
2995 Tool Bar\", \"Top\", \"Bottom\", \"Left\", or \"Right\". If this
2996 variable is set to anything other than \"Same As Default Tool
2997 Bar\" and the default tool bar is in a different location, then
2998 two tool bars will be displayed: the MH-E tool bar and the
2999 default tool bar."
3000 :type '(radio (const :tag "Same As Default Tool Bar" :value nil)
3001 (const :tag "Top" :value top)
3002 (const :tag "Bottom" :value bottom)
3003 (const :tag "Left" :value left)
3004 (const :tag "Right" :value right))
3005 :group 'mh-tool-bar
3006 :package-version '(MH-E . "7.3")))
3010 ;;; Hooks (:group 'mh-hooks + group where hook described)
3012 (defcustom-mh mh-after-commands-processed-hook nil
3013 "Hook run by \\<mh-folder-mode-map>\\[mh-execute-commands] after performing outstanding refile and delete requests.
3015 Variables that are useful in this hook include
3016 `mh-folders-changed', which lists which folders were affected by
3017 deletes and refiles. This list will always include the current
3018 folder, which is also available in `mh-current-folder'."
3019 :type 'hook
3020 :group 'mh-hooks
3021 :group 'mh-folder
3022 :package-version '(MH-E . "8.0"))
3024 (defcustom-mh mh-alias-reloaded-hook nil
3025 "Hook run by `mh-alias-reload' after loading aliases."
3026 :type 'hook
3027 :group 'mh-hooks
3028 :group 'mh-alias
3029 :package-version '(MH-E . "8.0"))
3031 (defcustom-mh mh-annotate-msg-hook nil
3032 "Hook run by `mh-annotate-msg' after annotation.
3033 Variables that are useful in this hook include `mh-current-folder',
3034 the current folder, and `mh-annotate-list', the messages annotated."
3035 :type 'hook
3036 :group 'mh-hooks
3037 :group 'mh-sending-mail
3038 :package-version '(MH-E . "8.1"))
3040 (defcustom-mh mh-before-commands-processed-hook nil
3041 "Hook run by \\<mh-folder-mode-map>\\[mh-execute-commands] before performing outstanding refile and delete requests.
3043 Variables that are useful in this hook include `mh-delete-list'
3044 and `mh-refile-list' which can be used to see which changes will
3045 be made to the current folder, `mh-current-folder'."
3046 :type 'hook
3047 :group 'mh-hooks
3048 :group 'mh-folder
3049 :package-version '(MH-E . "8.0"))
3051 (defcustom-mh mh-before-quit-hook nil
3052 "Hook run by \\<mh-folder-mode-map>\\[mh-quit] before quitting MH-E.
3054 This hook is called before the quit occurs, so you might use it
3055 to perform any MH-E operations; you could perform some query and
3056 abort the quit or call `mh-execute-commands', for example.
3058 See also `mh-quit-hook'."
3059 :type 'hook
3060 :group 'mh-hooks
3061 :group 'mh-folder
3062 :package-version '(MH-E . "6.0"))
3064 (defcustom-mh mh-before-send-letter-hook nil
3065 "Hook run at the beginning of the \\<mh-letter-mode-map>\\[mh-send-letter] command.
3067 For example, if you want to check your spelling in your message
3068 before sending, add the `ispell-message' function."
3069 :type 'hook
3070 :options '(ispell-message)
3071 :group 'mh-hooks
3072 :group 'mh-letter
3073 :package-version '(MH-E . "6.0"))
3075 (defcustom-mh mh-delete-msg-hook nil
3076 "Hook run by \\<mh-letter-mode-map>\\[mh-delete-msg] after marking each message for deletion.
3078 For example, a past maintainer of MH-E used this once when he
3079 kept statistics on his mail usage."
3080 :type 'hook
3081 :group 'mh-hooks
3082 :group 'mh-show
3083 :package-version '(MH-E . "6.0"))
3085 (defcustom-mh mh-find-path-hook nil
3086 "Hook run by `mh-find-path' after reading the user's MH profile.
3088 This hook can be used the change the value of the variables that
3089 `mh-find-path' sets if you need to run with different values
3090 between MH and MH-E."
3091 :type 'hook
3092 :group 'mh-hooks
3093 :group 'mh-e
3094 :package-version '(MH-E . "7.0"))
3096 (defcustom-mh mh-folder-mode-hook nil
3097 "Hook run by `mh-folder-mode' when visiting a new folder."
3098 :type 'hook
3099 :group 'mh-hooks
3100 :group 'mh-folder
3101 :package-version '(MH-E . "6.0"))
3103 (defcustom-mh mh-forward-hook nil
3104 "Hook run by `mh-forward' on a forwarded letter."
3105 :type 'hook
3106 :group 'mh-hooks
3107 :group 'mh-sending-mail
3108 :package-version '(MH-E . "8.0"))
3110 (defcustom-mh mh-inc-folder-hook nil
3111 "Hook run by \\<mh-folder-mode-map>\\[mh-inc-folder] after incorporating mail into a folder."
3112 :type 'hook
3113 :group 'mh-hooks
3114 :group 'mh-inc
3115 :package-version '(MH-E . "6.0"))
3117 (defcustom-mh mh-insert-signature-hook nil
3118 "Hook run by \\<mh-letter-mode-map>\\[mh-insert-signature] after signature has been inserted.
3120 Hook functions may access the actual name of the file or the
3121 function used to insert the signature with
3122 `mh-signature-file-name'."
3123 :type 'hook
3124 :group 'mh-hooks
3125 :group 'mh-letter
3126 :package-version '(MH-E . "8.0"))
3128 (defcustom-mh mh-kill-folder-suppress-prompt-hooks '(mh-search-p)
3129 "Abnormal hook run at the beginning of \\<mh-folder-mode-map>\\[mh-kill-folder].
3131 The hook functions are called with no arguments and should return
3132 a non-nil value to suppress the normal prompt when you remove a
3133 folder. This is useful for folders that are easily regenerated.
3135 The default value of `mh-search-p' suppresses the prompt on
3136 folders generated by searching.
3138 WARNING: Use this hook with care. If there is a bug in your hook
3139 which returns t on \"+inbox\" and you hit \\[mh-kill-folder] by
3140 accident in the \"+inbox\" folder, you will not be happy."
3141 :type 'hook
3142 :group 'mh-hooks
3143 :group 'mh-folder
3144 :package-version '(MH-E . "7.4"))
3146 (defcustom-mh mh-letter-mode-hook nil
3147 "Hook run by `mh-letter-mode' on a new letter.
3149 This hook allows you to do some processing before editing a
3150 letter. For example, you may wish to modify the header after
3151 \"repl\" has done its work, or you may have a complicated
3152 \"components\" file and need to tell MH-E where the cursor should
3153 go."
3154 :type 'hook
3155 :group 'mh-hooks
3156 :group 'mh-sending-mail
3157 :package-version '(MH-E . "6.0"))
3159 (defcustom-mh mh-mh-to-mime-hook nil
3160 "Hook run on the formatted letter by \\<mh-letter-mode-map>\\[mh-mh-to-mime]."
3161 :type 'hook
3162 :group 'mh-hooks
3163 :group 'mh-letter
3164 :package-version '(MH-E . "8.0"))
3166 (defcustom-mh mh-search-mode-hook nil
3167 "Hook run upon entry to `mh-search-mode'\\<mh-folder-mode-map>.
3169 If you find that you do the same thing over and over when editing
3170 the search template, you may wish to bind some shortcuts to keys.
3171 This can be done with this hook which is called when
3172 \\[mh-search] is run on a new pattern."
3173 :type 'hook
3174 :group 'mh-hooks
3175 :group 'mh-search
3176 :package-version '(MH-E . "8.0"))
3178 (defcustom-mh mh-quit-hook nil
3179 "Hook run by \\<mh-folder-mode-map>\\[mh-quit] after quitting MH-E.
3181 This hook is not run in an MH-E context, so you might use it to
3182 modify the window setup.
3184 See also `mh-before-quit-hook'."
3185 :type 'hook
3186 :group 'mh-hooks
3187 :group 'mh-folder
3188 :package-version '(MH-E . "6.0"))
3190 (defcustom-mh mh-refile-msg-hook nil
3191 "Hook run by \\<mh-folder-mode-map>\\[mh-refile-msg] after marking each message for refiling."
3192 :type 'hook
3193 :group 'mh-hooks
3194 :group 'mh-folder
3195 :package-version '(MH-E . "6.0"))
3197 (defcustom-mh mh-show-hook nil
3198 "Hook run after \\<mh-folder-mode-map>\\[mh-show] shows a message.
3200 It is the last thing called after messages are displayed. It's
3201 used to affect the behavior of MH-E in general or when
3202 `mh-show-mode-hook' is too early. See `mh-show-mode-hook'."
3203 :type 'hook
3204 :group 'mh-hooks
3205 :group 'mh-show
3206 :package-version '(MH-E . "6.0"))
3208 (defcustom-mh mh-show-mode-hook nil
3209 "Hook run upon entry to `mh-show-mode'.
3211 This hook is called early on in the process of the message
3212 display. It is usually used to perform some action on the
3213 message's content. See `mh-show-hook'."
3214 :type 'hook
3215 :group 'mh-hooks
3216 :group 'mh-show
3217 :package-version '(MH-E . "6.0"))
3219 (defcustom-mh mh-unseen-updated-hook nil
3220 "Hook run after the unseen sequence has been updated.
3222 The variable `mh-seen-list' can be used by this hook to obtain
3223 the list of messages which were removed from the unseen
3224 sequence."
3225 :type 'hook
3226 :group 'mh-hooks
3227 :group 'mh-sequences
3228 :package-version '(MH-E . "6.0"))
3232 ;;; Faces (:group 'mh-faces + group where faces described)
3234 (if (boundp 'facemenu-unlisted-faces)
3235 (add-to-list 'facemenu-unlisted-faces "^mh-"))
3237 ;; To add a new face:
3238 ;; 1. Add entry to variable mh-face-data.
3239 ;; 2. Create face using defface-mh (which removes min-color spec and
3240 ;; :package-version keyword where these are not supported),
3241 ;; accessing face data with function mh-face-data.
3242 ;; 3. Add inherit argument to function mh-face-data if applicable.
3243 (defvar mh-face-data
3244 '((mh-folder-followup
3245 ((((class color) (background light))
3246 (:foreground "blue3"))
3247 (((class color) (background dark))
3248 (:foreground "LightGoldenRod"))
3250 (:bold t))))
3251 (mh-folder-msg-number
3252 ((((class color) (min-colors 64) (background light))
3253 (:foreground "snow4"))
3254 (((class color) (min-colors 64) (background dark))
3255 (:foreground "snow3"))
3256 (((class color) (background light))
3257 (:foreground "purple"))
3258 (((class color) (background dark))
3259 (:foreground "cyan"))))
3260 (mh-folder-refiled
3261 ((((class color) (min-colors 64) (background light))
3262 (:foreground "DarkGoldenrod"))
3263 (((class color) (min-colors 64) (background dark))
3264 (:foreground "LightGoldenrod"))
3265 (((class color))
3266 (:foreground "yellow" :weight light))
3267 (((class grayscale) (background light))
3268 (:foreground "Gray90" :bold t :italic t))
3269 (((class grayscale) (background dark))
3270 (:foreground "DimGray" :bold t :italic t))
3272 (:bold t :italic t))))
3273 (mh-folder-subject
3274 ((((class color) (background light))
3275 (:foreground "blue4"))
3276 (((class color) (background dark))
3277 (:foreground "yellow"))
3279 (:bold t))))
3280 (mh-folder-tick
3281 ((((class color) (background light))
3282 (:background "#dddf7e"))
3283 (((class color) (background dark))
3284 (:background "#dddf7e"))
3286 (:underline t))))
3287 (mh-folder-to
3288 ((((class color) (min-colors 64) (background light))
3289 (:foreground "RosyBrown"))
3290 (((class color) (min-colors 64) (background dark))
3291 (:foreground "LightSalmon"))
3292 (((class color))
3293 (:foreground "green"))
3294 (((class grayscale) (background light))
3295 (:foreground "DimGray" :italic t))
3296 (((class grayscale) (background dark))
3297 (:foreground "LightGray" :italic t))
3299 (:italic t))))
3300 (mh-letter-header-field
3301 ((((class color) (background light))
3302 (:background "gray90"))
3303 (((class color) (background dark))
3304 (:background "gray10"))
3306 (:bold t))))
3307 (mh-search-folder
3308 ((((class color) (background light))
3309 (:foreground "dark green" :bold t))
3310 (((class color) (background dark))
3311 (:foreground "indian red" :bold t))
3313 (:bold t))))
3314 (mh-show-cc
3315 ((((class color) (min-colors 64) (background light))
3316 (:foreground "DarkGoldenrod"))
3317 (((class color) (min-colors 64) (background dark))
3318 (:foreground "LightGoldenrod"))
3319 (((class color))
3320 (:foreground "yellow" :weight light))
3321 (((class grayscale) (background light))
3322 (:foreground "Gray90" :bold t :italic t))
3323 (((class grayscale) (background dark))
3324 (:foreground "DimGray" :bold t :italic t))
3326 (:bold t :italic t))))
3327 (mh-show-date
3328 ((((class color) (min-colors 64) (background light))
3329 (:foreground "ForestGreen"))
3330 (((class color) (min-colors 64) (background dark))
3331 (:foreground "PaleGreen"))
3332 (((class color))
3333 (:foreground "green"))
3334 (((class grayscale) (background light))
3335 (:foreground "Gray90" :bold t))
3336 (((class grayscale) (background dark))
3337 (:foreground "DimGray" :bold t))
3339 (:bold t :underline t))))
3340 (mh-show-from
3341 ((((class color) (background light))
3342 (:foreground "red3"))
3343 (((class color) (background dark))
3344 (:foreground "cyan"))
3346 (:bold t))))
3347 (mh-show-header
3348 ((((class color) (min-colors 64) (background light))
3349 (:foreground "RosyBrown"))
3350 (((class color) (min-colors 64) (background dark))
3351 (:foreground "LightSalmon"))
3352 (((class color))
3353 (:foreground "green"))
3354 (((class grayscale) (background light))
3355 (:foreground "DimGray" :italic t))
3356 (((class grayscale) (background dark))
3357 (:foreground "LightGray" :italic t))
3359 (:italic t))))
3360 (mh-show-pgg-bad ((t (:bold t :foreground "DeepPink1"))))
3361 (mh-show-pgg-good ((t (:bold t :foreground "LimeGreen"))))
3362 (mh-show-pgg-unknown ((t (:bold t :foreground "DarkGoldenrod2"))))
3363 (mh-show-signature ((t (:italic t))))
3364 (mh-show-to
3365 ((((class color) (background light))
3366 (:foreground "SaddleBrown"))
3367 (((class color) (background dark))
3368 (:foreground "burlywood"))
3369 (((class grayscale) (background light))
3370 (:foreground "DimGray" :underline t))
3371 (((class grayscale) (background dark))
3372 (:foreground "LightGray" :underline t))
3373 (t (:underline t))))
3374 (mh-speedbar-folder
3375 ((((class color) (background light))
3376 (:foreground "blue4"))
3377 (((class color) (background dark))
3378 (:foreground "light blue"))))
3379 (mh-speedbar-selected-folder
3380 ((((class color) (background light))
3381 (:foreground "red1" :underline t))
3382 (((class color) (background dark))
3383 (:foreground "red1" :underline t))
3385 (:underline t)))))
3386 "MH-E face data.
3387 Used by function `mh-face-data' which returns spec that is
3388 consumed by `defface-mh'.")
3390 (require 'cus-face)
3392 (defvar mh-inherit-face-flag (assq :inherit custom-face-attributes)
3393 "Non-nil means that the `defface' :inherit keyword is available.
3394 The :inherit keyword is available on all supported versions of
3395 GNU Emacs and XEmacs from at least 21.5.23 on.")
3397 (defvar mh-min-colors-defined-flag (and (not (featurep 'xemacs))
3398 (>= emacs-major-version 22))
3399 "Non-nil means `defface' supports min-colors display requirement.")
3401 (defun mh-face-data (face &optional inherit)
3402 "Return spec for FACE.
3403 See `defface' for the spec definition.
3405 If INHERIT is non-nil and `defface' supports the :inherit
3406 keyword, return INHERIT literally; otherwise, return spec for
3407 FACE from the variable `mh-face-data'. This isn't a perfect
3408 implementation. In the case that the :inherit keyword is not
3409 supported, any additional attributes in the inherit parameter are
3410 not added to the returned spec.
3412 Furthermore, when `mh-min-colors-defined-flag' is nil, this
3413 function finds display entries with \"min-colors\" requirements
3414 and either removes the \"min-colors\" requirement or strips the
3415 display entirely if the display does not support the number of
3416 specified colors."
3417 (let ((spec
3418 (if (and inherit mh-inherit-face-flag)
3419 inherit
3420 (or (cadr (assq face mh-face-data))
3421 (error "Could not find %s in mh-face-data" face)))))
3423 (if mh-min-colors-defined-flag
3424 spec
3425 (let ((cells (mh-display-color-cells))
3426 new-spec)
3427 ;; Remove entries with min-colors, or delete them if we have
3428 ;; fewer colors than they specify.
3429 (loop for entry in (reverse spec) do
3430 (let ((requirement (if (eq (car entry) t)
3432 (assq 'min-colors (car entry)))))
3433 (if requirement
3434 (when (>= cells (nth 1 requirement))
3435 (setq new-spec (cons (cons (delq requirement (car entry))
3436 (cdr entry))
3437 new-spec)))
3438 (setq new-spec (cons entry new-spec)))))
3439 new-spec))))
3441 (defface-mh mh-folder-address
3442 (mh-face-data 'mh-folder-subject '((t (:inherit mh-folder-subject))))
3443 "Recipient face."
3444 :group 'mh-faces
3445 :group 'mh-folder
3446 :package-version '(MH-E . "8.0"))
3448 (defface-mh mh-folder-body
3449 (mh-face-data 'mh-folder-msg-number
3450 '((((class color))
3451 (:inherit mh-folder-msg-number))
3453 (:inherit mh-folder-msg-number :italic t))))
3454 "Body text face."
3455 :group 'mh-faces
3456 :group 'mh-folder
3457 :package-version '(MH-E . "8.0"))
3459 (defface-mh mh-folder-cur-msg-number
3460 (mh-face-data 'mh-folder-msg-number
3461 '((t (:inherit mh-folder-msg-number :bold t))))
3462 "Current message number face."
3463 :group 'mh-faces
3464 :group 'mh-folder
3465 :package-version '(MH-E . "8.0"))
3467 (defface-mh mh-folder-date
3468 (mh-face-data 'mh-folder-msg-number '((t (:inherit mh-folder-msg-number))))
3469 "Date face."
3470 :group 'mh-faces
3471 :group 'mh-folder
3472 :package-version '(MH-E . "8.0"))
3474 (defface-mh mh-folder-deleted
3475 (mh-face-data 'mh-folder-msg-number '((t (:inherit mh-folder-msg-number))))
3476 "Deleted message face."
3477 :group 'mh-faces
3478 :group 'mh-folder
3479 :package-version '(MH-E . "8.0"))
3481 (defface-mh mh-folder-followup (mh-face-data 'mh-folder-followup)
3482 "\"Re:\" face."
3483 :group 'mh-faces
3484 :group 'mh-folder
3485 :package-version '(MH-E . "8.0"))
3487 (defface-mh mh-folder-msg-number (mh-face-data 'mh-folder-msg-number)
3488 "Message number face."
3489 :group 'mh-faces
3490 :group 'mh-folder
3491 :package-version '(MH-E . "8.0"))
3493 (defface-mh mh-folder-refiled (mh-face-data 'mh-folder-refiled)
3494 "Refiled message face."
3495 :group 'mh-faces
3496 :group 'mh-folder
3497 :package-version '(MH-E . "8.0"))
3499 (defface-mh mh-folder-sent-to-me-hint
3500 (mh-face-data 'mh-folder-msg-number '((t (:inherit mh-folder-date))))
3501 "Fontification hint face in messages sent directly to us.
3502 The detection of messages sent to us is governed by the scan
3503 format `mh-scan-format-nmh' and the regular expression
3504 `mh-scan-sent-to-me-sender-regexp'."
3505 :group 'mh-faces
3506 :group 'mh-folder
3507 :package-version '(MH-E . "8.0"))
3509 (defface-mh mh-folder-sent-to-me-sender
3510 (mh-face-data 'mh-folder-followup '((t (:inherit mh-folder-followup))))
3511 "Sender face in messages sent directly to us.
3512 The detection of messages sent to us is governed by the scan
3513 format `mh-scan-format-nmh' and the regular expression
3514 `mh-scan-sent-to-me-sender-regexp'."
3515 :group 'mh-faces
3516 :group 'mh-folder
3517 :package-version '(MH-E . "8.0"))
3519 (defface-mh mh-folder-subject (mh-face-data 'mh-folder-subject)
3520 "Subject face."
3521 :group 'mh-faces
3522 :group 'mh-folder
3523 :package-version '(MH-E . "8.0"))
3525 (defface-mh mh-folder-tick (mh-face-data 'mh-folder-tick)
3526 "Ticked message face."
3527 :group 'mh-faces
3528 :group 'mh-folder
3529 :package-version '(MH-E . "8.0"))
3531 (defface-mh mh-folder-to (mh-face-data 'mh-folder-to)
3532 "\"To:\" face."
3533 :group 'mh-faces
3534 :group 'mh-folder
3535 :package-version '(MH-E . "8.0"))
3537 (defface-mh mh-letter-header-field (mh-face-data 'mh-letter-header-field)
3538 "Editable header field value face in draft buffers."
3539 :group 'mh-faces
3540 :group 'mh-letter
3541 :package-version '(MH-E . "8.0"))
3543 (defface-mh mh-search-folder (mh-face-data 'mh-search-folder)
3544 "Folder heading face in MH-Folder buffers created by searches."
3545 :group 'mh-faces
3546 :group 'mh-search
3547 :package-version '(MH-E . "8.0"))
3549 (defface-mh mh-show-cc (mh-face-data 'mh-show-cc)
3550 "Face used to highlight \"cc:\" header fields."
3551 :group 'mh-faces
3552 :group 'mh-show
3553 :package-version '(MH-E . "8.0"))
3555 (defface-mh mh-show-date (mh-face-data 'mh-show-date)
3556 "Face used to highlight \"Date:\" header fields."
3557 :group 'mh-faces
3558 :group 'mh-show
3559 :package-version '(MH-E . "8.0"))
3561 (defface-mh mh-show-from (mh-face-data 'mh-show-from)
3562 "Face used to highlight \"From:\" header fields."
3563 :group 'mh-faces
3564 :group 'mh-show
3565 :package-version '(MH-E . "8.0"))
3567 (defface-mh mh-show-header (mh-face-data 'mh-show-header)
3568 "Face used to deemphasize less interesting header fields."
3569 :group 'mh-faces
3570 :group 'mh-show
3571 :package-version '(MH-E . "8.0"))
3573 (defface-mh mh-show-pgg-bad (mh-face-data 'mh-show-pgg-bad)
3574 "Bad PGG signature face."
3575 :group 'mh-faces
3576 :group 'mh-show
3577 :package-version '(MH-E . "8.0"))
3579 (defface-mh mh-show-pgg-good (mh-face-data 'mh-show-pgg-good)
3580 "Good PGG signature face."
3581 :group 'mh-faces
3582 :group 'mh-show
3583 :package-version '(MH-E . "8.0"))
3585 (defface-mh mh-show-pgg-unknown (mh-face-data 'mh-show-pgg-unknown)
3586 "Unknown or untrusted PGG signature face."
3587 :group 'mh-faces
3588 :group 'mh-show
3589 :package-version '(MH-E . "8.0"))
3591 (defface-mh mh-show-signature (mh-face-data 'mh-show-signature)
3592 "Signature face."
3593 :group 'mh-faces
3594 :group 'mh-show
3595 :package-version '(MH-E . "8.0"))
3597 (defface-mh mh-show-subject
3598 (mh-face-data 'mh-folder-subject '((t (:inherit mh-folder-subject))))
3599 "Face used to highlight \"Subject:\" header fields."
3600 :group 'mh-faces
3601 :group 'mh-show
3602 :package-version '(MH-E . "8.0"))
3604 (defface-mh mh-show-to (mh-face-data 'mh-show-to)
3605 "Face used to highlight \"To:\" header fields."
3606 :group 'mh-faces
3607 :group 'mh-show
3608 :package-version '(MH-E . "8.0"))
3610 (defface-mh mh-show-xface
3611 (mh-face-data 'mh-show-from '((t (:inherit (mh-show-from highlight)))))
3612 "X-Face image face.
3613 The background and foreground are used in the image."
3614 :group 'mh-faces
3615 :group 'mh-show
3616 :package-version '(MH-E . "8.0"))
3618 (defface-mh mh-speedbar-folder (mh-face-data 'mh-speedbar-folder)
3619 "Basic folder face."
3620 :group 'mh-faces
3621 :group 'mh-speedbar
3622 :package-version '(MH-E . "8.0"))
3624 (defface-mh mh-speedbar-folder-with-unseen-messages
3625 (mh-face-data 'mh-speedbar-folder
3626 '((t (:inherit mh-speedbar-folder :bold t))))
3627 "Folder face when folder contains unread messages."
3628 :group 'mh-faces
3629 :group 'mh-speedbar
3630 :package-version '(MH-E . "8.0"))
3632 (defface-mh mh-speedbar-selected-folder
3633 (mh-face-data 'mh-speedbar-selected-folder)
3634 "Selected folder face."
3635 :group 'mh-faces
3636 :group 'mh-speedbar
3637 :package-version '(MH-E . "8.0"))
3639 (defface-mh mh-speedbar-selected-folder-with-unseen-messages
3640 (mh-face-data 'mh-speedbar-selected-folder
3641 '((t (:inherit mh-speedbar-selected-folder :bold t))))
3642 "Selected folder face when folder contains unread messages."
3643 :group 'mh-faces
3644 :group 'mh-speedbar
3645 :package-version '(MH-E . "8.0"))
3647 (provide 'mh-e)
3649 ;; Local Variables:
3650 ;; indent-tabs-mode: nil
3651 ;; sentence-end-double-space: nil
3652 ;; End:
3654 ;; arch-tag: cce884de-bd37-4104-9963-e4439d5ed22b
3655 ;;; mh-e.el ends here