]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix imenu--sort-by-position for non-pairs parameters (bug#26457)
authorDamien Cassou <damien@cassou.me>
Wed, 12 Apr 2017 05:35:56 +0000 (07:35 +0200)
committerNicolas Petton <nicolas@petton.fr>
Thu, 13 Apr 2017 09:44:17 +0000 (11:44 +0200)
* lisp/imenu.el (imenu--sort-by-position): Fix to accept lists beyond
  pairs.
* test/lisp/imenu-tests.el: Add 2 tests for `imenu--sort-by-position`.

lisp/imenu.el
test/lisp/imenu-tests.el

index 0f47a92734ea656b9067d372bc0faad6098bc68a..c1fd4005ab6bd097d16d4b422a037bfa47cb8436 100644 (file)
@@ -499,7 +499,12 @@ An item looks like (NAME . POSITION)."
   (string-lessp (car item1) (car item2)))
 
 (defun imenu--sort-by-position (item1 item2)
-  (< (cdr item1) (cdr item2)))
+  "Comparison function to sort items depending on their position.
+Return non-nil if and only if ITEM1's position is lower than ITEM2's
+position."
+  (if (listp (cdr item1))
+      (< (cadr item1) (cadr item2))
+    (< (cdr item1) (cdr item2))))
 
 (defun imenu--relative-position (&optional reverse)
   "Support function to calculate relative position in buffer.
index 480368fcbb636313191f691cd9726118119dd995..93090947139332101c0c62bb22035542328e0cda 100644 (file)
@@ -83,6 +83,16 @@ function ABC_D()
 }
 " '("a" "b" "c" "ABC_D"))
 
+(ert-deftest imenu--sort-by-position-pairs ()
+  (should (imenu--sort-by-position '("a" . 2) '("a" . 3)))
+  (should-not (imenu--sort-by-position '("a" . 3) '("a" . 2))))
+
+;; Regression test for bug#26457: 25.2; Cannot pass a function to
+;; imenu-generic-expression
+(ert-deftest imenu--sort-by-position-list ()
+  (should (imenu--sort-by-position '("a" 2 nil) '("a" 3 nil)))
+  (should-not (imenu--sort-by-position '("a" 3 nil) '("a" 2 nil))))
+
 (provide 'imenu-tests)
 
 ;;; imenu-tests.el ends here