From f7c4478f99f24baa774b3b9e17a46a0b1a050bda Mon Sep 17 00:00:00 2001 From: Stefan Monnier Date: Mon, 5 Jun 2000 07:15:58 +0000 Subject: [PATCH] (mh-send-sub): Check mh-etc is bound before using it. (mh-letter-mode): Derive from text-mode. This implicitly means that it now calls kill-all-local-variables. Also remove the Emacs-18 compatibility code. --- lisp/ChangeLog | 5 +++++ lisp/mail/mh-comp.el | 25 ++++++++----------------- 2 files changed, 13 insertions(+), 17 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 46e78137c20..2d4fa55229b 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,5 +1,10 @@ 2000-06-05 Stefan Monnier + * mail/mh-comp.el (mh-send-sub): Check mh-etc is bound before using it. + (mh-letter-mode): Derive from text-mode. + This implicitly means that it now calls kill-all-local-variables. + Also remove the Emacs-18 compatibility code. + * emacs-lisp/autoload.el (make-autoload): Simplify docstring. Make use of symbol-property doc-string-elt. Use memq rather than a sequence of eq. diff --git a/lisp/mail/mh-comp.el b/lisp/mail/mh-comp.el index 0a0841b2e6c..5b8828201f2 100644 --- a/lisp/mail/mh-comp.el +++ b/lisp/mail/mh-comp.el @@ -26,7 +26,7 @@ ;;; Change Log: -;; $Id: mh-comp.el,v 1.16 1999/11/10 10:46:01 gerd Exp $ +;; $Id: mh-comp.el,v 1.17 2000/04/27 18:56:42 gerd Exp $ ;;; Code: @@ -517,7 +517,9 @@ See also documentation for `\\[mh-send]' function." components) ((file-exists-p (setq components - (expand-file-name mh-comp-formfile mh-etc))) + (expand-file-name mh-comp-formfile + ;; What is this mh-etc ?? -sm + (and (boundp 'mh-etc) mh-etc)))) components) (t (error (format "Can't find components file \"%s\"" @@ -691,7 +693,7 @@ See also documentation for `\\[mh-send]' function." (put 'mh-letter-mode 'mode-class 'special) ;;;###autoload -(defun mh-letter-mode () +(define-derived-mode mh-letter-mode text-mode "MH-Letter" "Mode for composing letters in mh-e.\\ When you have finished composing, type \\[mh-send-letter] to send the message using the MH mail handling system. @@ -720,8 +722,6 @@ Variables controlling this mode (defaults in parentheses): File to be inserted into message by \\[mh-insert-signature]. This command runs the normal hooks `text-mode-hook' and `mh-letter-mode-hook'." - - (interactive) (or mh-user-path (mh-find-path)) (make-local-variable 'paragraph-start) (setq paragraph-start (concat "^[ \t]*[-_][-_][-_]+$\\|" paragraph-start)) @@ -736,19 +736,10 @@ This command runs the normal hooks `text-mode-hook' and `mh-letter-mode-hook'." (make-local-variable 'mh-sent-from-msg) (make-local-variable 'mail-header-separator) (setq mail-header-separator "--------") ;for Hyperbole - (use-local-map mh-letter-mode-map) - (setq major-mode 'mh-letter-mode) - (mh-set-mode-name "MH-Letter") - (set-syntax-table mh-letter-mode-syntax-table) - (run-hooks 'text-mode-hook) ;; if text-mode-hook turned on auto-fill, tune it for messages - (cond ((and (boundp 'auto-fill-hook) auto-fill-hook) ;emacs 18 - (make-local-variable 'auto-fill-hook) - (setq auto-fill-hook 'mh-auto-fill-for-letter))) - (cond ((and (boundp 'auto-fill-function) auto-fill-function) ;emacs 19 - (make-local-variable 'auto-fill-function) - (setq auto-fill-function 'mh-auto-fill-for-letter))) - (run-hooks 'mh-letter-mode-hook)) + (when auto-fill-function + (make-local-variable 'auto-fill-function) + (setq auto-fill-function 'mh-auto-fill-for-letter))) (defun mh-auto-fill-for-letter () -- 2.39.2