Skip to content

Commit fe29a03

Browse files
dakrabbatsov
authored andcommitted
Fix imenu with Clojure code in string or comment
Ignore error that's thrown from `down-list` when called with point inside a string or comment. E.g. with code like: ``` (defn foo [] (let [a " (defn b [_] (bar {:bla \"bla\"}))"])) ``` `clojure-match-next-def` calls `down-list` with point inside the string and `down-list` will throw an user-error with "This command doesn't work in strings or comments". This user-error in `down-list` got introduced 2022-05-06 with https://git.savannah.gnu.org/cgit/emacs.git/commit/?id=0b3b295776ce723885c9997ab26d57314db2a5df The `when ignore-errors` could be replaced with `unless (ppss-comment-or-string-start (syntax-ppss))` once the minimum requirement for clojure-mode is Emacs 27.
1 parent 3717e44 commit fe29a03

File tree

2 files changed

+4
-1
lines changed

2 files changed

+4
-1
lines changed

CHANGELOG.md

+1
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@
1111

1212
* [#581](https://github.com/clojure-emacs/clojure-mode/issues/581): Fix font locking not working for keywords starting with a number.
1313
* [#377](https://github.com/clojure-emacs/clojure-mode/issues/377): Fix everything starting with the prefix 'def' being highlighted as a definition form. Now definition forms are enumerated explicitly in the font-locking code, like all other forms.
14+
* [#638](https://github.com/clojure-emacs/clojure-mode/pull/638): Fix imenu with Clojure code in string or comment.
1415

1516
## 5.15.1 (2022-07-30)
1617

clojure-mode.el

+3-1
Original file line numberDiff line numberDiff line change
@@ -777,7 +777,9 @@ Called by `imenu--generic-function'."
777777
(let (found?
778778
(deftype (match-string 2))
779779
(start (point)))
780-
(down-list)
780+
;; ignore user-error from down-list when called from inside a string or comment
781+
(ignore-errors
782+
(down-list))
781783
(forward-sexp)
782784
(while (not found?)
783785
(ignore-errors

0 commit comments

Comments
 (0)