diff options
| author | Daniel Colascione <dancol@dancol.org> | 2014-01-13 15:50:20 -0800 |
|---|---|---|
| committer | Daniel Colascione <dancol@dancol.org> | 2014-01-13 15:50:20 -0800 |
| commit | c176054fe1e2e72fb1c34d56658269361bacadd3 (patch) | |
| tree | ace1ad22b97d7866f804002aab1277b9a56adfab /lisp/textmodes | |
| parent | 1b49bd5d72d012cd349c29822fd6985bb4e5a158 (diff) | |
| download | emacs-c176054fe1e2e72fb1c34d56658269361bacadd3.tar.gz | |
Fix rst-mode deprecated keybindings
Diffstat (limited to 'lisp/textmodes')
| -rw-r--r-- | lisp/textmodes/rst.el | 33 |
1 files changed, 22 insertions, 11 deletions
diff --git a/lisp/textmodes/rst.el b/lisp/textmodes/rst.el index a533bdb75e3..516431006f6 100644 --- a/lisp/textmodes/rst.el +++ b/lisp/textmodes/rst.el @@ -611,17 +611,28 @@ KEYMAP, KEY, and DEF are as in `define-key'. DEPRECATED key definitions should be in vector notation. These are defined as well but give an additional message." (define-key keymap key def) - (dolist (dep-key deprecated) - (define-key keymap dep-key - `(lambda () - ,(format "Deprecated binding for %s, use \\[%s] instead." def def) - (interactive) - (call-interactively ',def) - (message "[Deprecated use of key %s; use key %s instead]" - (key-description (this-command-keys)) - (key-description ,key)))))) - -;; Key bindings. + (when deprecated + (let* ((command-name (symbol-name def)) + (forwarder-function-name + (if (string-match "^rst-\\(.*\\)$" command-name) + (concat "rst-deprecated-" + (match-string 1 command-name)) + (error "not an RST command: %s" command-name))) + (forwarder-function (intern forwarder-function-name))) + (unless (fboundp forwarder-function) + (defalias forwarder-function + (lexical-let ((key key) (def def)) + (lambda () + (interactive) + (call-interactively def) + (message "[Deprecated use of key %s; use key %s instead]" + (key-description (this-command-keys)) + (key-description key)))) + (format "Deprecated binding for %s, use \\[%s] instead." + def def))) + (dolist (dep-key deprecated) + (define-key keymap dep-key forwarder-function))))) + ;; Key bindings. (defvar rst-mode-map (let ((map (make-sparse-keymap))) |
