3 This is a major release which includes a lot of new features including
4 improved MIME handling, speedbar folder browsing, and indexed
5 searching. In this version, MH-E runs under XEmacs, passes checkdoc,
6 and compiles clean under all supported platforms.
8 The "passes checkdoc" feature above required changing the name of
9 several user-visible variables. It is likely that this affects you.
10 Please be sure to see the table at the end of these notes and rename
11 your variables accordingly.
13 MH-E has been written mh-e, Mh-e, MH-e and MH-E. We have decided that
14 the proper term should be MH-E. Please try to use MH-E in your
17 ** New Features in MH-E 7.0
21 There is now support for the speedbar. Try "M-x speedbar" (closes SF
24 Press the middle mouse button on the `+' icons to open a folder,
25 middle mouse button on a folder name to open the folder. Folders with
26 unseen messages are shown in bold, so this is a handy way to browse
27 new messages that you have filed with procmail or slocal.
29 See the new customization variable `mh-large-folder,' which controls
30 when the speedbar asks for how many messages to scan when opening a
31 large folder and `mh-speed-run-flists-flag' whose default value of t
32 means to use the flists command to populate the count of unseen and
33 total messages in each folder.
37 Interoperability with swish++, swish, glimpse, and namazu has been
38 added to enable lightening-fast searches of your mail. If none of
39 these are present, grep is used. Try "F i (mh-index-search)".
41 For more information, read the documentation for the functions
42 `mh-swish++-execute-search,' `mh-swish-execute-search,'
43 `mh-namazu-execute-search,' or `mh-glimpse-execute-search' depending
44 on your preferred indexing program to see what kind of setup is needed
45 to generate the index.
49 Use "T t (mh-toggle-threads)" to view the threads in the folder. Use
50 it again to return to a non-threaded view.
54 Use "? (mh-help)" and "X ? (mh-prefix-help)," where X is a prefix
55 character, for a brief synopsis in the minibuffer of frequently used
56 commands. In the MH-Letter or MH-Pick buffers, use "C-c ? (mh-help)"
59 *** Folder Keymap Shared by Show Buffer
61 You can now use the MH-Folder mode commands from the MH-Show buffer.
62 Because of this, the MH-Show buffer is now read-only (closes SF
63 #493749 and SF #527946) and you now have to use "M (mh-modify)" to
68 You no longer have to modify your scan format if your folders have
69 more than 9999 messages in them. If you've only modified your scan
70 format file to allow for the wider message numbers, consider using the
71 default behavior of MH-E and simplify your MH-E configuration
72 considerably (closes SF #635791).
74 To do this, you may have to remove your modifications of
75 `mh-scan.*-regexp' and `mh-cmd-note' and your customization of
76 `mh-scan-format-file'.
78 You may still want the updated format files for running MH commands
79 outside of MH-E; the default of `mh-scan-format-file' will cause them
82 If you prefer fixed-width message numbers, set the new customization
83 variable to nil , set this variable to
84 nil and call `mh-set-cmd-note' with the width specified by the scan format in
85 `mh-scan-format-file'. For example, the default width is 4, so you would use
86 "(mh-set-cmd-note 4)" if `mh-scan-format-file' were nil.
90 MH-E now displays the content of the X-Face header field in the From
91 field. When sending a message, an X-Face field is appended to the
92 header if it doesn't already exist and "~/.face" is present. See the
93 new customization variables `mh-show-use-xface-flag' and `mh-x-face-file'
96 MH-E depends on the external x-face package found in
97 ftp://ftp.jpl.org/pub/elisp/ to do this. The `uncompface' binary is
98 also required to be in the execute PATH. It can be obtained from:
99 http://freshmeat.net/redir/compface/1439/url_tgz/compface-1.4.tar.gz.
101 It has also been observed that if you don't see the faces, you might
102 have to do this (for unknown reasons):
104 mv /usr/local/include/compface.h /usr/include/
106 *** Graphical Smileys
108 Smiley's are now converted to cute little images. See the new
109 customization variable `mh-graphical-smileys-flag.'
113 ASCII formatting is now converted to the appropriate font. For
114 example, _underline_ is underlined, *bold* appears in bold, /italic/
115 appears in italic, etc. See `gnus-emphasis-alist' for the whole list.
116 See the new customization variables `mh-decode-mime' and
117 `mh-graphical-emphasis-flag.'
119 *** Attachment Handling
121 Inline attachments are now displayed. Regular attachments appear as
122 buttons in show buffer. Use "K TAB (mh-next-button)" or "K SHIFT-TAB
123 (mh-prev-button)" to cycle through these buttons. Use "K v
124 (mh-folder-toggle-mime-part)" to view, "K o
125 (mh-folder-save-mime-part)" to save one part or "K-a
126 (mh-save-mime-parts)" to save all parts, or "K i
127 (mh-folder-inline-mime-part)" to view the attachment inline.
129 See the new customization variable `mh-decode-mime' for additional
130 information. Other customization variables that affect this new feature
131 include `mh-store-mime-parts-default-directory' and
132 `mh-display-buttons-for-inline-parts-flag'.
134 HTML documents can be viewed inline if Gnus v5.10 and w3 or w3m lisp
135 packages are present. Set the customization variable
136 `mm-text-html-renderer' accordingly (closes SF #453352).
138 *** Quoted-printable Handling
140 Quoted-printable body parts are now decoded.
142 *** More Choices for `mh-yank-from-start-of-msg'
144 Historically, if this variable was t, the entire message, with full
145 headers would be included and every line would begin with
146 `mh-ins-buf-prefix.' This usage is deprecated in favor of the setting
147 `supercite' below. The default has been changed to `attribution.' The
148 following symbols are now understood:
150 `body': yank the message minus the header.
152 `supercite': include the entire message, with full headers. This also
153 causes the invocation of `sc-cite-original' without the setting of
154 `mail-citation-hook', now deprecated practice.
156 `autosupercite': do as for `supercite' automatically when show buffer
157 matches the message being replied-to.
159 `attribution': yank the message minus the header and add a simple
160 attribution line at the top.
162 `autoattrib': do as for `attribution' automatically when show buffer
163 matches the message being replied-to.
165 There is a new customization variable called
166 `mh-extract-from-attribution-verb' which is used for attribution which
167 provides a method for setting a different language.
169 *** Use Gnus mml Instead of mhn
171 When inserting attachments into a message draft, Gnus mml directives
172 are now used instead of mhn directives. One beneficial side-effect of
173 this is that attachments can now appear inline as well as separate.
175 The new customization variable `mh-compose-insertion' controls whether
176 Gnus or mhn is used to insert MIME message directives in messages
177 (default: 'gnus, if the mml library exists).
179 *** Content-Type Now Obtained Automatically
181 The value of the Content-Type no longer needs to be entered by the
184 *** Attachments Automatically Included Upon Send
186 You no longer have to run "C-c C-e (mh-edit-mhn)" before sending a
187 message with attachments--this is done automatically when you send the
188 message with "C-c C-c (mh-send-letter)". There is, however, a new key
189 binding "C-c C-m m (mh-mml-to-mime)" which is analogous to "C-c C-e
194 Messages that have been signed or encrypted with GPG are verified and
195 decrypted automatically. To sign or encrypt a message, use "C-c RET
196 C-s (mh-mml-secure-message-sign-pgpmime)" and "C-c C-m C-e
197 (mh-mml-secure-message-encrypt-pgpmime)." You need Gnus version 5.10
198 for this feature. These functions are provided by the pgg.el package.
200 Users report "flashing" with the pgg.el package and prefer the gpg.el
201 package instead. To use gpg.el instead of the pgg.el package you need:
203 (setq mml2015-use 'gpg)
205 To mimic automatic encryption in gpg.el, use:
207 (setq mm-verify-option 'always)
208 (setq mm-decrypt-option 'always)
210 The venerable mailcrypt package is also an option. However, now that
211 show buffers are read-only, mailcrypt version 3.5.6 and older fail
212 when they attempt to decrypt the contents.
214 *** Mail-Followup-To Header Field
216 Support for this controversial field has been added because nmh
217 supports it (closes SF #627035). If you want to add it to outgoing
218 mail for selected mailing lists, add those mailing lists to the new
219 customization variable `mh-insert-mail-followup-to-list.' If you think
220 this field is evil, set the new customization variable
221 `mh-insert-mail-followup-to-flag' to nil.
225 If you update Gnus, you must recompile MH-E. Note that if you are
226 running the stock version of MH-E that comes with Emacs or the MH-E
227 package on a Debian GNU/Linux, this is done for you.
229 ** New Variables in MH-E 7.0
231 New customization variables not mentioned earlier include:
233 *** mh-letter-insert-signature-hook
235 Invoked at the beginning of the "C-c C-s (mh-insert-signature)"
236 command. Can be used to determine which signature file to use based on
237 message content. On return, if `mh-signature-file-name' is non-nil
238 that file will be inserted at the current point in the buffer.
240 *** mh-show-maximum-size
242 Maximum size of message (in bytes) to display automatically. Provides
243 an opportunity to skip over large messages which may be slow to load.
244 Use a value of 0 to display all messages automatically regardless of
245 size (closes SF #488696).
247 *** mh-tool-bar-reply-3-buttons-flag
249 Non-nil means use three buttons for reply commands in tool-bar. If you
250 have room on your tool-bar because you are using a large font, you may
251 set this variable to expand the single reply button into three buttons
252 that won't lead to minibuffer prompt about who to reply to.
254 ** Bug Fixes in MH-E 7.0
256 *** mh-delete-msg, mh-refile-msg, mh-undo
258 Mandrake Linux includes XEmacs initialization code that binds
259 `transient-mark-mode' which causes problems in MH-E. These problems
260 have been fixed (closes SF #541915).
264 This would sometimes yield a read-only buffer. This has been fixed
265 (closes SF #624283 and SF #625538).
269 When using nmh, always specify -mime so as to preserve the original
274 If you had narrowed to a sequence and then incorporated new mail,
275 those new messages would not be present in your +inbox when you
276 widened. This has been fixed (closes SF #489430, SF #489437, SF
281 No longer uses mhl to include a message as this mangled the header and
282 gave supercite fits (closes SF #629153).
286 "M-q (fill-paragraph)" now fills quoted paragraphs (for example,
287 starting with "> ") correctly (closes SF #489927).
289 *** mh-next-undeleted-msg, mh-previous-undeleted-msg
291 If there are no more undeleted messages the point remains at its
292 original position and a message is produced (closes SF #494304).
296 Now calls `mh-pick-mode-hook' as documented.
298 *** mh-put-msg-in-seq
300 Now puts all messages in region in sequence (closes SF #630324).
302 *** mh-refile-msg, mh-write-msg-to-file
304 These functions stomped on the variables that held the name of the
305 last file and folder respectively for the other function. This has
306 been fixed so that the last folder or file name is preserved (closes
309 *** mh-region-to-sequence
311 If the region in MH-Folder was set with "C-x h (mark-whole-buffer)",
312 you couldn't perform operations on all of the messages as you would
313 expect. This has been fixed (closes SF #621632).
317 Performing an undo the first thing after replying would blank out the
318 entire draft. Now just the insertion of the yanked message is undone
319 leaving the header and signature intact for additional editing (closes
324 Now calls `mh-show-mode-hook' as documented (closes SF #627222).
326 *** mh-subject-thread-to-sequence
328 Make 'subject sequence a real one, exported to MH. This means you can,
329 for example, mh-forward it. But it also shows up with a mark in the
330 scan output (closes SF #489445).
334 The following bugs have also been closed:
336 SF #495450: Folder buffer read-only after inc
337 SF #489706: mh-page-msg bombs out
338 SF #580772: mh-last-destination is overloaded
340 *** Variables renamed to conform with Emacs coding conventions
342 The coding conventions require that boolean variables end in -flag.
343 The following two tables show which variables were affected (closes SF
346 Customization Variables (defcustom)
350 mh-auto-folder-collect mh-auto-folder-collect-flag
351 mh-bury-show-buffer mh-bury-show-buffer-flag
352 mh-clean-message-header mh-clean-message-header-flag
353 mh-decode-quoted-printable mh-decode-quoted-printable-flag
354 mh-delete-yanked-msg-window mh-delete-yanked-msg-window-flag
355 mh-do-not-confirm mh-do-not-confirm-flag
356 mh-highlight-citation-p mh-highlight-citation
357 mh-insert-x-mailer-p mh-insert-x-mailer-flag
358 mh-print-background mh-print-background-flag
359 mh-recenter-summary-p mh-recenter-summary-flag
360 mh-recursive-folders mh-recursive-folders-flag
361 mh-reply-show-message-p mh-reply-show-message-flag
362 mh-show-use-goto-addr mh-show-use-goto-addr-flag
363 mh-update-sequences-after-mh-show mh-update-sequences-after-mh-show-flag
365 Regular Variables (defvar)
369 mh-mhn-compose-insert-p mh-mhn-compose-insert-flag
371 mh-page-to-next-msg-p mh-page-to-next-msg-flag
375 * Changes in mh-e 6.1
377 This is a minor release which includes a few bug fixes. The
378 distribution now includes the ChangeLog.
380 ** New Features in mh-e 6.1
384 Unseen messages now displayed in bold.
386 *** Viewing folders and sequences
388 The folder and sequence listings that "F l (mh-list-folders)" and "S l
389 (mh-list-sequences)" create are now displayed in view mode.
391 ** Bug Fixes in mh-e 6.1
393 *** mh-folder-unseen-seq-name
395 Byte compilation failed when initializing this variable when the
396 user's MH environment was not set up. This has been fixed (closes
397 Debian #140232 and Debian #140817).
401 When forwarding a sequence, the mode of the draft would not be set to
402 MH-Letter correctly. This has been fixed (closes SF #489448).
404 *** mh-insert-prefix-string
406 Fixed to work under XEmacs. Thanks to Will Partain
407 <partain at dcs.gla.ac.uk>.
411 mh-quit now cleans up the buffers named `mh-temp-buffer,'
412 'mh-temp-folders-buffer' and 'mh-temp-sequences-buffer.'
415 * Changes in mh-e 6.0
417 mh-e is now maintained at SourceForge (see
418 http://mh-e.sourceforge.net/). This is where you need to go to obtain
419 new versions of mh-e, report bugs and receive support.
421 The maintainers have moved much of their personal configurations into
422 the codebase, so you may find that you may be able to reduce your mh-e
423 customizations as well.
425 There are several incompatibilities in this version from older
426 versions. Please read the following notes carefully for details. Pay
427 particular attention to the key binding changes in the MH-Folder
428 section. If you have customized your scan format, you will want to
429 read about the new variable `mh-scan-format-file'.
431 The manual could not be updated in time for this release. It will be
432 updated in the near future. If the Preface in your manual indicates
433 the older version (version 1.3, for mh-e version 5.0.2), please check
434 the following page occasionally for an update:
436 https://sourceforge.net/project/showfiles.php?group_id=13357
439 ** New Features in mh-e 6.0
443 mh-e now uses the customize feature of Emacs. Use "M-x customize-group
444 mh RET" to customize mh-e.
448 All mh-e modes now provide menus that contain most mh-e functions.
452 All mh-e modes now have toolbar buttons for oft-used functions (Emacs 21).
456 All mh-e buffers now have font-lock keywords. To use, either call
457 (turn-on-font-lock) from the appropriate hook, or set
458 `global-font-lock-mode' to t. To customize, use "M-x
459 customize-apropos-faces ^mh RET".
461 If you have customized your scan lines, you will have to update your
462 scan regexps. The existing regexps were changed to extract a match so
463 you will have to add appropriate grouping constructs to take advantage
464 of the fontification. Your old settings will continue to work, but the
465 folder will not be fontified. For example:
467 (setq mh-good-msg-regexp "^\\(.....\\)[^D^]")
469 You will most likely have to update the new variable
470 `mh-scan-subject-regexp' as well. There is another new variable
471 `mh-scan-date-regexp' which you may also find useful. Run "M-x apropos
472 mh.*regexp" for a complete list.
474 *** mail-user-agent support
476 You can now set `mail-user-agent' to `mh-e-user-agent' so that packages
477 that need to send mail will use mh-e (closes SF #406883, SF #470024).
479 *** replgroupcomps support
481 If you reply to `cc' or `all' and you use nmh, the nmh repl option
482 -group will be used. This means that the file `replgroupcomps' will be
483 used. If you have customized `replcomps', you will definitely want to
484 either copy `$NMH_LIB/replgroupcomps' to your mail directory and modify
485 it the same way that you modified your `replcomps' file, or simply
486 copy your `replcomps' file to `replgroupcomps'.
490 The variable `mh-summary-height' used to have a default of 4. It now
491 varies from 4 to 10 depending on the height of the frame.
493 Clicking the mouse on a message shows that message.
495 Delete, refile and undo now operate on a region (but only if
496 `transient-mark-mode' is non-nil).
498 SPC (mh-page-msg) now displays the message if it is not already
499 visible. If the bottom of a message is showing, SPC (mh-page-msg)
500 moves to the next message (respecting the direction you are moving
503 The threading commands "T u (mh-next-unseen-subject-thread)",
504 "T t (mh-toggle-subject-thread)", "T s (mh-narrow-to-subject-thread)",
505 and "T k (mh-delete-subject-thread)" have been added. These functions
506 do not offer threading in the true sense of the word, but do allow
507 some manipulation by subject.
509 Major, major keymap changes. This was done to free up movement
510 commands in the buffer, and to provide for additional features, such
511 as the threading commands. At the same time, better and more
512 consistent mnemonics were realized that should make it easier to
513 remember key bindings.
515 Added new sub-keymaps for folder commands, sequence commands,
516 extraction commands, and digest commands which begin with with F, S,
517 X, and D, respectively. These sub-keymaps allowed some consistency
518 (e.g., especially with l(ist) and k(ill)).
520 Here are the actual changes and rationale:
524 e - Deleted. Already have x. Now used by mh-edit-again.
525 j - Deleted. Already have g.
527 M-a e Better mnemonic. Matches rmail. Frees movement command.
528 M-e E Better mnemonic. Consistent with e.
529 - S Why not? mh-sort-folder.
531 M-f Fv Frees movement command
534 M-k Fk No reason but to keep with folder commands
535 M-l Fl No reason but to keep with folder commands
536 M-p Fp No reason but to keep with folder commands
537 M-r Fr Frees movement command
538 M-s Fs No reason but to keep with folder commands
539 M-u Fu No reason but to keep with folder commands
541 M-% Sd Better mnemonic
542 M-# Sk Better mnemonic
543 M-q Sl Better mnemonic
544 C-xn Sn Frees up standard key binding
545 % Sp Better mnemonic for putting a message in a sequence
546 ? Ss Shows sequences that message is in
547 C-xw Sw Frees up standard key binding
549 M-n Xs Better mnemonic (extract shar)
550 M-n Xu Better mnemonic (extract uuencode)
552 M-SPC D SPC Frees mark command
553 M-\177 D \177 No reason but to keep with digest commands
554 M-b Db Frees movement command
556 As the number of variables increases, it is becoming important to
557 organize the mh-e namespace. Several variables having to do with the
558 format of scan lines were renamed, as follows:
562 mh-good-msg-regexp mh-scan-good-msg-regexp
563 mh-deleted-msg-regexp mh-scan-deleted-msg-regexp
564 mh-refiled-msg-regexp mh-scan-refiled-msg-regexp
565 mh-valid-scan-line mh-scan-valid-regexp
566 mh-cur-scan-msg-regexp mh-scan-cur-msg-number-regexp
567 - mh-scan-cur-msg-regexp
568 - mh-scan-rcpt-regexp
569 - mh-scan-format-regexp
570 mh-msg-number-regexp mh-scan-msg-number-regexp
571 mh-msg-search-regexp mh-scan-msg-search-regexp
575 While the MIME support is not complete, quoted-printable body parts
578 Some MTAs quote From at the beginning of the line with a ">". The ">"
579 is now removed in the display, but not on disk.
583 New function "C-c C-o (mh-split-line)" splits lines in a draft
584 preserving the fill prefix and indentation. This is useful when
585 responding to several sentences in a single paragraph separately.
587 "M-q (fill-paragraph)" can now be used on the message that is being
588 replied to. The fill prefix such as "> " is preserved.
590 You no longer have to run "C-c C-e (mh-edit-mhn)" manually as this is
591 now done automatically when the message is sent.
593 The X-Mailer header field is now added to messages as they are sent.
595 "C-c C-m C-i (mh-mhn-compose-insertion)" now makes a pretty good guess
596 at the type of file using the `file' command and no longer asks the
597 user for the media type. If the necessary version of `file' is not
598 available, the user is asked for the media type as before; however,
599 the list of media types is now taken from the system mailcap if
600 available. Failing that, the built-in list of types has been
601 supplemented so in most cases the type you need should be present
602 (closes SF #406883, #441179).
604 ** New Variables in mh-e 6.0
606 New variables not mentioned earlier include:
608 *** mh-insert-x-mailer-p
610 Default value of t means that an X-Mailer header field should be
613 *** mh-reply-show-message-p
615 The setting of this variable determines whether the MH show-buffer is
616 displayed with the current message when using mh-reply without a prefix
617 argument. Set it to nil if you already include the message
618 automatically in your draft using "repl: -filter repl.filter" in
621 *** mh-scan-format-file
623 Specifies the format file to pass to the scan program. If t, the
624 format string will be taken from the either `mh-scan-format-mh' or
625 `mh-scan-format-nmh' depending on whether MH or nmh is in use. If nil,
626 the default scan output will be used.
628 If you customize the scan format, you may need to modify a few
629 variables containing regexps that mh-e uses to identify specific
630 portions of the output. Use `M-x apropos RET mh-scan.*regexp' to
631 obtain a list of these variables.
633 *** mh-scan-format-mh
635 Scan format string for MH, provided to the scan program via the
636 -format arg. This format is identical to the default except that
637 additional hints for fontification have been added to the sixth
640 *** mh-scan-format-nmh
642 Scan format string for nmh, provided to the scan program via the
643 -format arg. This format is identical to the default except that
644 additional hints for fontification have been added to the sixth
647 *** mh-show-use-goto-addr
649 Non-nil means URLs and e-mail addresses are highlighted using
650 goto-addr in MH-Show buffer.
652 *** mh-letter-fill-column
654 Fill column to use in `mh-letter-mode'. This is useful to make the
655 lines a bit shorter to allow for quoting in replies.
657 *** mh-folder-updated-hook
659 Invoked when the actions in a folder (such as moves and deletes) are
660 performed. Variables that are useful in this hook include
661 `mh-delete-list' and `mh-refile-list' which can be used to see which
662 changes are being made to current folder, `mh-current-folder'.
664 *** mh-unseen-updated-hook
666 Invoked after the unseen sequence has been updated. The variable
667 `mh-seen-list' can be used to obtain the list of messages which will
668 be removed from the unseen sequence
670 ** Bug Fixes in mh-e 6.0
672 *** mh-edit-again and mh-extract-rejected-mail
674 Now insert a header separator (--------) which packages such as
679 Now uses `mhparam' to set `mh-lib-progs' and `mh-lib'. Added more
680 directories to `mh-progs' so that mh-e can autoconfigure in more
681 environments. Chances are that you no longer have to set these
682 variables, and if you do, you will only have to set `mh-progs'.
683 Unless, of course, you are using an ancient version of MH that doesn't
686 *** mh-folder-mode-map
688 The DEL/<delete>/<backspace> change in Emacs 21 broke
689 `mh-previous-page'. This has been fixed (closes SF #228907).
693 If you had "forw: -mime" to your .mh_profile, forwarding a message
696 Search failed: "^------- Forwarded Message"
698 In addition, the Subject field was not filled in. This has been fixed
703 The user is now always prompted before this action; the variable
704 `mh-do-not-confirm' is no longer consulted here. Therefore users who
705 wanted to set `mh-do-not-confirm' but didn't because of the
706 `mh-kill-folder' dependency may now do so.
708 *** mh-make-folder-mode-line
710 Properly deals with folders that do not have any lines in them. Prints
711 "no msgs" instead of "0 msgs". Does not try to print a range when
712 there are no messages.
714 *** mh-mhn-compose-insertion
716 Now gets the MIME type automatically (assuming the local file command
717 supports the -i and -b options). If this use of the file command is
718 not supported, the list of MIME types has been expanded to use the
719 system's mailcap file.
723 This variable (t when nmh is in use rather than MH) assumed that the
724 string "nmh" is in `mh-lib-progs' or `mh-lib'. This has been fixed
729 No longer lets you specify an empty folder (closes SF #476824).
731 *** mh-regenerate-headers
733 Now suppresses "scan: bad message list" messages.
737 This function was looking for `mhl' in the wrong place on nmh on
738 Redhat LINUX 7.0. This has been fixed (closes SF #481128).
742 Now updates `cur' sequence after a message is shown (closes SF #481772).
746 Renamed variable and function to `mh-showing-mode' to conform with
747 minor mode conventions. Added optional arg to function so it would
748 behave like a normal minor mode: no or nil arg toggles mode, 0 arg
749 turns off, non-nil turns on. This fixed the error that occurred when
750 `desktop-create-buffer' recreated mh-e buffers because it was calling
751 `mh-showing' with an arg.
755 Fixed for nmh. Now displays mh-e version correctly. Cleaned up output
756 and display `mh-progs', etc.
760 Now attempts to stay on the same message number (closes SF #480922).
762 No longer wipes out pending deletes and refiles without warning
766 * Changes in mh-e 5.0.2
768 This version contains additional minor changes to integrate it with
769 reporter.el (requires reporter.el version 3.1c or later) and Emacs
770 19.30. The mh-goto-msg function is much faster, which also speeds up
771 several other operations.
774 * Changes in mh-e 5.0.1
776 This version contains minor changes from mh-e 5.0 to integrate it with
780 * User-visible changes to mh-e 5.0
782 Note: This being a major release, there are many internal changes.
783 This document lists only changes to the external interfaces of mh-e.
785 When upgrading, you must either explicitly reload the new versions of
786 all mh-e files that are already loaded or restart your Emacs.
789 ** Major Changes and New Features in mh-e 5.0
791 The emphasis for this release has been on consistency and
792 documentation. Many documentation strings were enhanced. Documentation
793 strings were changed to comments for internal functions and variables.
795 *** There is now proper documentation in the form of a 75-page users
796 manual. The Texinfo source is mh-e.texi; the formatted Info document
799 *** There is a new command `mh-update-sequences', which updates MH's
800 idea of what messages are in the Unseen sequence and what is the
801 current folder and message. `mh-quit' calls it. While
802 `mh-execute-commands' has always done this updating as a side effect,
803 the new function is faster.
805 *** The MH profile entry "Inbox:" is supported.
807 *** If the show-buffer is modified, the user is queried before mh-e
808 reuses the buffer to show a different message. This buffer is also
809 auto-saved and backed up correctly.
811 *** `mh-store-buffer' is significantly more robust. It now handles
812 messages created by a wide variety of packaging software. The status
813 message for `uudecode' includes the name of the file created. An error
814 is signaled if the subprocess exits with a non-zero status.
816 *** `mh-search-folder' behaves predictably, adding messages found to
817 the `search' sequence. It correctly handles the case of no messages
820 *** `mh-burst-digest' (`M-b') now only rescans the part of the folder
821 affected by the burst. It is now much faster in a large folder.
824 ** New Hooks and Customization Variables in mh-e 5.0
826 *** `mh-default-folder-for-message-function': new name for the old
827 `mh-msg-folder-hook', which wasn't a hook. The old name was confusing,
828 leading people to think they could use `add-hook' with it, when
829 actually `setq' is the correct way.
831 *** `mh-sortm-args': When this variable is used has changed. Now
832 `mh-sortm-args' is passed if there IS a prefix argument to
833 `mh-sort-folder'. The assumption is that for arguments you normally
834 want, you would specify them in an MH profile entry.
836 *** `mh-mhn-args': new hook, a list of additional arguments to pass to
837 the `mhn' program if `mh-edit-mhn' is given a prefix argument.
839 *** `mh-edit-mhn-hook': new hook called by `mh-edit-mhn', the function
840 that formats MIME messages.
842 *** `mh-folder-list-change-hook': new hook, called whenever the cached
843 list of folders, `mh-folder-list', is changed.
845 *** `mh-find-path-hook': new hook, called when entering mh-e.
847 *** `mh-repl-formfile': new variable, used to change the format file
848 used by `mh-reply' from the default of "replcomps".
850 *** New variables to customize the scan format and notating:
851 `mh-note-deleted', `mh-note-refiled', `mh-note-seq', `mh-note-cur',
852 `mh-note-copied', `mh-note-printed'.
855 ** Key Binding Changes in mh-e 5.0
857 *** `RET' runs `mh-show' for consistency with the Finder and Info. The
858 old binding `.' still works, but `RET' is now the standard binding.
860 *** `M-<' now runs `mh-first-msg' for consistency with `M->', which
863 *** `C-c C-f C-d' in MH-Letter mode moves to a Dcc: header field.
865 *** `C-c C-f C-r' in MH-Letter mode moves to a From: header field.
867 *** `g' is now the standard binding for `mh-goto-msg'. The old binding
871 ** Other Improvements and Changes to mh-e 5.0
873 *** `mh-lpr-command-format' no longer passes the "-p" argument to
874 `lpr' by default. The mail header typically has the date anyway.
876 *** When prompting for a sequence name, if no sequences have been used
877 yet, mh-e will offer the first sequence the current message is in.
879 *** The patterns of more mailers are recognized by
880 `mh-extract-rejected-mail'.
882 *** `mh-insert-prefix-string' no longer wraps the call to the
883 `mail-citation-hook' function in a `save-excursion' so the hook writer
884 can choose whether to leave point at the beginning or the end of the
887 *** `mh-write-msg-to-file': The prompt now refers to "message" or
888 "message body" depending on which will be written. (This is controlled
889 by a prefix argument.) The file defaults to the last-used file instead
890 of supplying only the directory name.
892 *** mh-e uses message ranges when running MH commands. Thus "rmm 1 2 3
893 4 6" is now "rmm 1-4 6". This change makes it less likely to overflow
894 system argument list limits, and it might be faster, too.
897 ** Bug Fixes to mh-e 5.0
899 *** mh-e's idea of the unseen sequence now stays in sync with MH's
902 *** Functions that are supposed to find fields in the message header
903 no longer look in the message body.
905 *** mh-e would sometimes fail to remove the "%" from a scan line when
906 the message was removed from a sequence if the message was also in the
909 *** The variable `mh-inc-prog' is now correctly used in all places.
911 *** `mh-pipe-msg' runs the process in the correct directory.
913 *** A partially scanned folder will no longer lose the "/select"
914 annotation when you execute marked deletes and refiles with `x'.
917 * Changes to mh-e 4.0
919 This file is automatically generated from news-mh-e.txinfo. Do not edit.
921 [MH-E-ONEWS has been incorporated here and removed. news-mh-e.txinfo
922 is no longer available.]
924 Note: there are many internal changes to mh-e in this release. If you
925 have the previous version loaded into your Emacs, you will probably not
926 be able to load this version on top of it.
928 ** New Features in mh-e 4.0
930 *** Background folder collection. The first time you are prompted for
931 a folder, you must wait while mh-e collects the names of all existing
932 folders. Now however, if you abort, collecting will continue in the
933 background, and you can do something else in Emacs until the
934 collection completes. Normally, mh-e will begin collecting folders
935 names in the background when you first load it; you can disable this
936 feature by setting `mh-auto-folder-collect' to nil.
938 *** There is support for composing MIME messages using the `mhn'
939 program from MH 6.8. See the documentation string for mh-edit-mhn.
940 (While composing a letter, type `C-h k C-c C-e'.) See also mhn(1).
941 There is as yet no support for reading MIME messages.
943 *** `mh-show', typically on `.', repositions to the start of the
944 message if the message is already visible. It used to do nothing in
947 *** The function `mh-unshar-msg' is renamed `mh-store-msg'. It now
948 does uudecoding, too. Someday it should do MIME. It remembers the last
949 directory you used and offers it as the default for next time.
951 *** New function `mh-header-display', on `,', displays the message
952 with all headers, including those normally not displayed. Type `.' to
953 display the message normally again.
955 *** New function `mh-list-sequences' lists the sequences in use in the
958 *** New function `mh-version' displays version information about MH
959 and mh-e. Please use the output in bug reports.
961 *** `mh-quit' now burys the folder buffer and show buffer.
964 ** New hooks and customization variables in mh-e 4.0
966 *** `mh-pick-mode-hook': new hook called by new mode `mh-pick-mode'.
967 The pick buffer didn't used to have its own mode. Another advantage of
968 `mh-pick-mode' is that `C-h m' works in the pick buffer.
970 *** `mail-citation-hook': new variable for supercite.
972 *** `mh-refile-msg-hook': new hook called by `mh-refile-msg' (and
973 `mh-refile-or-write-again' when refiling).
975 *** `mh-msg-folder-hook': new hook used by `mh-refile-msg' and
976 `mh-to-fcc' to provide a default folder for user prompt.
978 *** `mh-show-hook': new hook called by `mh-show'.
980 *** `mh-delete-msg-hook': new hook called by `mh-delete-msg'.
982 *** `mh-show-mode-hook': new hook called by new mode `mh-show-mode'
985 *** `mh-comp-formfile': new variable so can customize `components'
988 *** `mh-sortm-args': new variable, a list of extra arguments to be
989 passed to sortm by `mh-sort-folder'. Give an argument to
990 `mh-sort-folder' to suppress this behavior.
992 *** `mh-send-prog': new variable so can customize name of `send'
993 program in case of name conflicts.
995 *** `mh-scan-prog': new variable so can customize name of `scan'
996 program to generate custom effects.
998 *** `mh-inc-prog': new variable so can customize name of `inc' program
999 to do fancy management of incoming messages.
1001 *** `mh-forwarded-letter-subject': new function used by `mh-forward'
1002 to compute the Subject line of the new message. It is a small function
1003 which can be replaced by the user for customization. Uses the new
1004 variable `mh-forward-subject-format', which allows some simple
1005 customizations without rewriting even `mh-forwarded-letter-subject'.
1007 *** `mh-new-draft-cleaned-headers': new variable, header lines removed
1008 by `mh-edit-again' and `mh-extract-rejected-mail' before offering a
1009 message as a new draft.
1011 *** `mh-signature-file-name': new variable used by
1012 `mh-insert-signature' to so can customize name of the file to insert.
1014 *** `mh-read-address': new function called to read all To: and Cc:
1017 *** `mh-msg-folder-hook': new hook used by `mh-refile-msg' and
1018 `mh-to-fcc' to provide a default folder for user prompt.
1021 ** Key binding changes in mh-e 4.0
1023 *** `,' runs new function `mh-header-display'. It is like `.' but it
1024 displays *all* the headers.
1026 *** `M-#' runs the new function `mh-delete-seq'. One used to have to
1027 type `C-u M-%' to delete a sequence.
1029 *** `<' no longer does `mh-first-msg', but `M->' now does
1030 `mh-last-msg'. This allows first and last to be consistent (`>' was
1031 taken) and is more likely to be discovered by chance anyway.
1033 *** `M-d' runs `mh-redistribute', `r' runs `mh-reply' (on the theory
1034 that the more commonly used function should be easier to type, and the
1035 obscure action of redistributing can be harder to type).
1037 *** `M-o' changed to `C-o' (`mh-write-msg-to-file'). It was
1038 interfering with arrow keys for some people.
1040 *** `M-n' now runs `mh-store-msg' (formerly `mh-unshar-msg').
1042 *** `b' no longer runs `mh-quit'; use `q' instead. `b' may be used in
1043 a future version for something else.
1046 ** Minor improvements to mh-e 4.0
1048 *** The mh-e code is now divided into multiple Emacs Lisp files, so it
1049 starts up faster because Emacs doesn't have to load all of it at once.
1050 (This change also makes it easier for the maintainer to manage
1053 *** When searching for the directory containing the MH programs,
1054 search the user's PATH in addition to the built-in directories, to
1055 increase the chance of finding the MH programs.
1057 *** The subject for a forwarded message no longer has ugly square
1060 *** The name of the folder is no longer appears twice in the show
1063 *** When typing a folder name in the minibuffer, parent folders
1064 complete to the trailing slash (/), for easier typing of subfolders.
1066 *** The folder buffer mode name changed from `mh-e scan' or `mh-e
1067 show' to `MH-Folder', which makes the hook name easier to guess. Added
1068 `mh-showing' to `minor-mode-alist' so there is still an indication in
1069 the mode line of whether messages will be shown automatically.
1071 *** `mh-rename-seq' does completion on the old sequence name.
1073 *** If called by a user who has never used MH on this system before,
1074 mh-e runs the MH program `install-mh' to get them set up.
1076 *** Undo history for previous messages is not kept to avoid wasting
1079 *** The internal temp buffer used by mh-e has `buffer-offer-save'
1080 explicitly nil. This change benefits people who change the
1081 `buffer-offer-save' default.
1084 ** Bug fixes to mh-e 4.0
1086 *** `mh-to-field': don't bomb if no To: field.
1088 *** `mh-get-new-mail': restore annotations, e.g., cur, even if no new
1091 *** `mh-rename-seq': verify that the new seq name was accepted by
1092 `mark' before updating state.
1094 *** `mh-internal-seq': the Previous sequence is not notated, since it
1095 would notate everything scanned.
1097 *** `mh-read-draft': don't call `find-file-noselect' so an
1098 `auto-mode-alist' doesn't trigger `mh-letter-mode-hook' twice. Faster,
1101 *** `mh-show': If user moves onto a message that doesn't exist, don't
1102 leave the cursor in the show pane.
1104 *** `mh-delete-scan-msgs': use `equal', not `=', on the result of
1105 `mh-get-msg-num', since it may be nil.
1107 *** `mh-get-field': do anchored search so searching for `reply-to:'
1108 doesn't find `in-reply-to:'.
1110 *** `mh-widen': do nothing if not narrowed.
1112 *** `mh-clean-message-header': find end of headers even if no body.
1117 paragraph-separate: "[
\f]*$"