]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix `pr-interface'
authorRobert Pluim <rpluim@gmail.com>
Fri, 6 Jan 2023 08:00:00 +0000 (09:00 +0100)
committerRobert Pluim <rpluim@gmail.com>
Fri, 6 Jan 2023 09:06:25 +0000 (10:06 +0100)
`pr-interface' specifies `inline' for its menu items, which is not
necessary, but it causes `widget-choice-value-create' to bug
out.  (Bug#60501)

* lisp/wid-edit.el (widget-choice-value-create): Allow the value to be
a non-list.
* test/lisp/wid-edit-tests.el (widget-test-handle-spurious-inline):
Add test to ensure that unnecessary :inline is allowed.

lisp/wid-edit.el
test/lisp/wid-edit-tests.el

index 798db9f9dd299d78511b74307a3e232e8e715bf6..60bd2baa6fb442e0f8b4720e3050d3667db3fc83 100644 (file)
@@ -2220,7 +2220,9 @@ But if NO-TRUNCATE is non-nil, include them."
             (if (widget-get current :inline)
                 (setq val value
                       fun :match-inline)
-              (setq val (car value)
+              (setq val (if (consp value)
+                            (car value)
+                          value)
                     fun :match))
           (setq val value
                 fun :match))
index 3f5fcea0c33bddeb5ee475d50ed925cc630d712c..b379c7c91a878c0a6a9175c0d361e9546d3d4a1d 100644 (file)
@@ -267,6 +267,22 @@ return nil, even with a non-nil bubblep argument."
       (should child)
       (should (equal (widget-value widget) '(1 "One"))))))
 
+;; Bug#60501
+(ert-deftest widget-test-handle-spurious-inline ()
+  "Test the we can create a menu widget with an unnecessary :inline"
+  (with-temp-buffer
+    (widget-insert "Testing.\n\n")
+    (let* ((widget (widget-create 'menu-choice
+                                  :inline t
+                                  :value "*scratch*"
+                                  '(choice-item "*scratch*")))
+           (child (car (widget-get widget :children))))
+      (widget-insert "\n")
+      (use-local-map widget-keymap)
+      (widget-setup)
+      (should child)
+      (should (string-equal (widget-value widget) "*scratch*")))))
+
 (ert-deftest widget-test-option-can-handle-choice ()
   "Test that we can create a option widget with a choice correctly."
   (with-temp-buffer