# HG changeset patch # User Juri Linkov # Date 1133663621 0 # Node ID ada17aff9ef82599a4db6bf86102b82044ceaada # Parent cf5b42f7a962b58e234f3e133f0d8e09d52b793c (define-derived-mode): Put `definition-name' properties on the constructed variable names. diff -r cf5b42f7a962 -r ada17aff9ef8 lisp/emacs-lisp/derived.el --- a/lisp/emacs-lisp/derived.el Sun Dec 04 02:32:35 2005 +0000 +++ b/lisp/emacs-lisp/derived.el Sun Dec 04 02:33:41 2005 +0000 @@ -200,12 +200,19 @@ No problems result if this variable is not bound. `add-hook' automatically binds it. (This is true for all hook variables.)" name))) + (unless (boundp ',map) + (put ',map 'definition-name ',child)) (defvar ,map (make-sparse-keymap)) ,(if declare-syntax - `(defvar ,syntax (make-syntax-table))) + `(progn + (unless (boundp ',syntax) + (put ',syntax 'definition-name ',child)) + (defvar ,syntax (make-syntax-table)))) ,(if declare-abbrev - `(defvar ,abbrev - (progn (define-abbrev-table ',abbrev nil) ,abbrev))) + `(progn + (put ',abbrev 'definition-name ',child) + (defvar ,abbrev + (progn (define-abbrev-table ',abbrev nil) ,abbrev)))) (put ',child 'derived-mode-parent ',parent) ,(if group `(put ',child 'custom-mode-group ,group))