From: Stefan Monnier Date: Mon, 7 Oct 2013 05:13:51 +0000 (-0400) Subject: * lisp/emacs-lisp/easymenu.el (easy-menu-create-menu): Use closures. X-Git-Tag: emacs-24.3.90~173^2^2~42^2~45^2~387^2~1361 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=731fc3aec85564ab026964dd4dee361f786bcfa3;p=emacs.git * lisp/emacs-lisp/easymenu.el (easy-menu-create-menu): Use closures. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 6e6c0aaa671..bceb4959171 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,5 +1,7 @@ 2013-10-07 Stefan Monnier + * emacs-lisp/easymenu.el (easy-menu-create-menu): Use closures. + * emacs-lisp/lisp-mode.el (eval-defun-2): Simplify, using lexical-binding. * emacs-lisp/tq.el (tq-create): Use a closure instead of `(lambda...). diff --git a/lisp/emacs-lisp/easymenu.el b/lisp/emacs-lisp/easymenu.el index f33ae54bf25..924ca7c0547 100644 --- a/lisp/emacs-lisp/easymenu.el +++ b/lisp/emacs-lisp/easymenu.el @@ -1,4 +1,4 @@ -;;; easymenu.el --- support the easymenu interface for defining a menu +;;; easymenu.el --- support the easymenu interface for defining a menu -*- lexical-binding:t -*- ;; Copyright (C) 1994, 1996, 1998-2013 Free Software Foundation, Inc. @@ -218,21 +218,22 @@ MENU-NAME is a string, the name of the menu. MENU-ITEMS is a list of items possibly preceded by keyword pairs as described in `easy-menu-define'." (let ((menu (make-sparse-keymap menu-name)) (easy-menu-avoid-duplicate-keys nil) - prop keyword arg label enable filter visible help) + prop keyword label enable filter visible help) ;; Look for keywords. (while (and menu-items (cdr menu-items) (keywordp (setq keyword (car menu-items)))) - (setq arg (cadr menu-items)) - (setq menu-items (cddr menu-items)) - (pcase keyword - (`:filter - (setq filter `(lambda (menu) - (easy-menu-filter-return (,arg menu) ,menu-name)))) - ((or `:enable `:active) (setq enable (or arg ''nil))) - (`:label (setq label arg)) - (`:help (setq help arg)) - ((or `:included `:visible) (setq visible (or arg ''nil))))) + (let ((arg (cadr menu-items))) + (setq menu-items (cddr menu-items)) + (pcase keyword + (`:filter + (setq filter (lambda (menu) + (easy-menu-filter-return (funcall arg menu) + menu-name)))) + ((or `:enable `:active) (setq enable (or arg ''nil))) + (`:label (setq label arg)) + (`:help (setq help arg)) + ((or `:included `:visible) (setq visible (or arg ''nil)))))) (if (equal visible ''nil) nil ; Invisible menu entry, return nil. (if (and visible (not (easy-menu-always-true-p visible))) @@ -496,7 +497,7 @@ Contrary to XEmacs, this is a nop on Emacs since menus are automatically \(fn MENU)") -(defun easy-menu-add (menu &optional map) +(defun easy-menu-add (_menu &optional _map) "Add the menu to the menubar. On Emacs, menus are already automatically activated when the corresponding keymap is activated. On XEmacs this is needed to