summaryrefslogtreecommitdiff
path: root/lisp/use-package
diff options
context:
space:
mode:
authorMatus Goljer <dota.keys@gmail.com>2014-02-18 13:40:25 +0100
committerMatus Goljer <dota.keys@gmail.com>2014-02-18 13:40:25 +0100
commitf90d65e1492a67433270402551608b46b75fca32 (patch)
tree87d2eef39870fa0e048ccd2a3514a41d089a6c1f /lisp/use-package
parentaec1268960ff1161d7339139ba6b88175bc6fd70 (diff)
downloademacs-f90d65e1492a67433270402551608b46b75fca32.tar.gz
emacs-f90d65e1492a67433270402551608b46b75fca32.tar.bz2
emacs-f90d65e1492a67433270402551608b46b75fca32.zip
Add better descriptions for lambdas, closures, keymaps
Diffstat (limited to 'lisp/use-package')
-rw-r--r--lisp/use-package/bind-key.el21
1 files changed, 18 insertions, 3 deletions
diff --git a/lisp/use-package/bind-key.el b/lisp/use-package/bind-key.el
index c15a4321ef9..a6bba121fe7 100644
--- a/lisp/use-package/bind-key.el
+++ b/lisp/use-package/bind-key.el
@@ -95,6 +95,11 @@
:type 'regexp
:group 'bind-key)
+(defcustom bind-key-describe-special-forms nil
+ "If non-nil, extract docstrings from lambdas, closures and keymaps if possible."
+ :type 'boolean
+ :group 'bind-key)
+
;; Create override-global-mode to force key remappings
(defvar override-global-map (make-keymap)
@@ -184,15 +189,25 @@ function symbol (unquoted)."
((listp elem)
(cond
((eq 'lambda (car elem))
- "#<lambda>")
+ (if (and bind-key-describe-special-forms
+ (stringp (nth 2 elem)))
+ (nth 2 elem)
+ "#<lambda>"))
((eq 'closure (car elem))
- "#<closure>")
+ (if (and bind-key-describe-special-forms
+ (stringp (nth 3 elem)))
+ (nth 3 elem)
+ "#<closure>"))
((eq 'keymap (car elem))
"#<keymap>")
(t
elem)))
((keymapp elem)
- "#<keymap>")
+ (if (and bind-key-describe-special-forms
+ (symbolp elem)
+ (get elem 'variable-documentation))
+ (format "%s" (get elem 'variable-documentation))
+ "#<keymap>"))
((symbolp elem)
elem)
(t