]> git.eshelyaron.com Git - emacs.git/commitdiff
Populate tool-bar bindings on text terminals
authorJared Finder <jared@finder.org>
Mon, 8 Jan 2024 21:20:25 +0000 (13:20 -0800)
committerEli Zaretskii <eliz@gnu.org>
Thu, 11 Jan 2024 10:49:27 +0000 (12:49 +0200)
* lisp/tool-bar.el (tool-bar-make-keymap-1): Populate on text
terminals.  (Bug#68334)

lisp/tool-bar.el

index 4ca81fb01e091c255714b76a89303bc76b2adf41..96b61c7b22957ffb5ba3316feaa8c2867736f268 100644 (file)
@@ -165,6 +165,8 @@ color capability and based on the available image libraries."
             base-keymap)
       base-keymap)))
 
+;; This function should return binds even if images can not be
+;; displayed so the tool bar can still be displayed on terminals.
 (defun tool-bar-make-keymap-1 (&optional map)
   "Generate an actual keymap from `tool-bar-map', without caching.
 MAP is either a keymap to use as a source for menu items, or nil,
@@ -180,15 +182,14 @@ in which case the value of `tool-bar-map' is used instead."
                         (consp image-exp)
                         (not (eq (car image-exp) 'image))
                         (fboundp (car image-exp)))
-               (if (not (display-images-p))
-                   (setq bind nil)
-                 (let ((image (eval image-exp)))
-                   (unless (and image (image-mask-p image))
-                     (setq image (append image '(:mask heuristic))))
-                   (setq bind (copy-sequence bind)
-                         plist (nthcdr (if (consp (nth 4 bind)) 5 4)
-                                       bind))
-                   (plist-put plist :image image))))
+               (let ((image (and (display-images-p)
+                                  (eval image-exp))))
+                 (unless (and image (image-mask-p image))
+                   (setq image (append image '(:mask heuristic))))
+                 (setq bind (copy-sequence bind)
+                       plist (nthcdr (if (consp (nth 4 bind)) 5 4)
+                                     bind))
+                 (plist-put plist :image image)))
              bind))
          (or map tool-bar-map)))