From: Leo Liu Date: Mon, 6 Oct 2014 03:59:38 +0000 (+0800) Subject: * imenu.el (imenu): Re-write for clarity. X-Git-Tag: emacs-25.0.90~2635^2~679^2~113 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=195c5c4c925cfced8d720659dc638b434282f29b;p=emacs.git * imenu.el (imenu): Re-write for clarity. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index a04e6d2b91d..c118209933d 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,7 @@ +2014-10-06 Leo Liu + + * imenu.el (imenu): Re-write for clarity. + 2014-10-06 Glenn Morris Remove calendar code obsolete since at least version 23.1. diff --git a/lisp/imenu.el b/lisp/imenu.el index 3159b6cc563..5bad4c09c44 100644 --- a/lisp/imenu.el +++ b/lisp/imenu.el @@ -1034,16 +1034,13 @@ for more information." (if (stringp index-item) (setq index-item (assoc index-item (imenu--make-index-alist)))) (when index-item - (push-mark nil t) - (let* ((is-special-item (listp (cdr index-item))) - (function - (if is-special-item - (nth 2 index-item) imenu-default-goto-function)) - (position (if is-special-item - (cadr index-item) (cdr index-item))) - (args (if is-special-item (cdr (cddr index-item))))) - (apply function (car index-item) position args)) - (run-hooks 'imenu-after-jump-hook))) + (pcase index-item + (`(,name ,pos ,fn . ,args) + (push-mark nil t) + (apply fn name pos args) + (run-hooks 'imenu-after-jump-hook)) + (`(,name . ,pos) (imenu (list name pos imenu-default-goto-function))) + (_ (error "Unknown imenu item: %S" index-item))))) (provide 'imenu)