summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp/easy-mmode.el
diff options
context:
space:
mode:
authorStefan Monnier <monnier@iro.umontreal.ca>2003-05-29 21:54:35 +0000
committerStefan Monnier <monnier@iro.umontreal.ca>2003-05-29 21:54:35 +0000
commit2e2a00756f442aa66230b260c1dba423502a365c (patch)
tree4a12a8760f119299e4e961dcbd1b33f27a605bf2 /lisp/emacs-lisp/easy-mmode.el
parentb02c53e6efe2557198c5db3466e698beae21026d (diff)
downloademacs-2e2a00756f442aa66230b260c1dba423502a365c.tar.gz
(define-minor-mode): Add edebug spec.
Accept a :keymap argument, as you'd expect.
Diffstat (limited to 'lisp/emacs-lisp/easy-mmode.el')
-rw-r--r--lisp/emacs-lisp/easy-mmode.el20
1 files changed, 15 insertions, 5 deletions
diff --git a/lisp/emacs-lisp/easy-mmode.el b/lisp/emacs-lisp/easy-mmode.el
index af47454ca4d..6b9c593915f 100644
--- a/lisp/emacs-lisp/easy-mmode.el
+++ b/lisp/emacs-lisp/easy-mmode.el
@@ -1,6 +1,6 @@
;;; easy-mmode.el --- easy definition for major and minor modes
-;; Copyright (C) 1997, 2000, 2001 Free Software Foundation, Inc.
+;; Copyright (C) 1997, 2000, 2001, 2003 Free Software Foundation, Inc.
;; Author: Georges Brun-Cottan <Georges.Brun-Cottan@inria.fr>
;; Maintainer: Stefan Monnier <monnier@gnu.org>
@@ -98,12 +98,19 @@ BODY contains code that will be executed each time the mode is (dis)activated.
By default, the mode is buffer-local.
:init-value VAL Same as the INIT-VALUE argument.
:lighter SPEC Same as the LIGHTER argument.
+:keymap MAP Same as the KEYMAP argument.
:require SYM Same as in `defcustom'.
For example, you could write
(define-minor-mode foo-mode \"If enabled, foo on you!\"
:lighter \" Foo\" :require 'foo :global t :group 'hassle :version \"27.5\"
...BODY CODE...)"
+ (declare (debug (&define name stringp
+ [&optional [&not keywordp] sexp
+ &optional [&not keywordp] sexp
+ &optional [&not keywordp] sexp]
+ [&rest [keywordp sexp]]
+ def-body)))
;; Allow skipping the first three args.
(cond
@@ -121,12 +128,10 @@ For example, you could write
(extra-args nil)
(extra-keywords nil)
(require t)
- (keymap-sym (if (and keymap (symbolp keymap)) keymap
- (intern (concat mode-name "-map"))))
(hook (intern (concat mode-name "-hook")))
(hook-on (intern (concat mode-name "-on-hook")))
(hook-off (intern (concat mode-name "-off-hook")))
- keyw)
+ keyw keymap-sym)
;; Check keys.
(while (keywordp (setq keyw (car body)))
@@ -138,8 +143,12 @@ For example, you could write
(:extra-args (setq extra-args (pop body)))
(:group (setq group (nconc group (list :group (pop body)))))
(:require (setq require (pop body)))
+ (:keymap (setq keymap (pop body)))
(t (push keyw extra-keywords) (push (pop body) extra-keywords))))
+ (setq keymap-sym (if (and keymap (symbolp keymap)) keymap
+ (intern (concat mode-name "-map"))))
+
(unless group
;; We might as well provide a best-guess default group.
(setq group
@@ -204,11 +213,12 @@ With zero or negative ARG turn mode off.
(progn
,(if globalp `(customize-mark-as-set ',mode))
(unless (current-message)
- (message ,(format "%s %%sabled" pretty-name)
+ (message ,(format "%s %%sabled" pretty-name)
(if ,mode "en" "dis")))))
(force-mode-line-update)
;; Return the new setting.
,mode)
+
;; Autoloading an easy-mmode-define-minor-mode autoloads
;; everything up-to-here.
:autoload-end