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