From: Mauro Aranda Date: Sat, 10 Aug 2019 13:48:24 +0000 (-0300) Subject: Don't display wrong ElDoc information when inside ELisp strings or comments X-Git-Tag: emacs-27.0.90~1562 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=4e0c5830dab466be2df99b8814b742a662d67ac7;p=emacs.git Don't display wrong ElDoc information when inside ELisp strings or comments * lisp/progmodes/elisp-mode.el (elisp--fnsym-in-current-sexp): Since forward-sexp assumes point is not in a string or comment, avoid calling it and then checking if point is inside a string, since that sometimes will fail with awkward results. (Bug#35567) --- diff --git a/lisp/progmodes/elisp-mode.el b/lisp/progmodes/elisp-mode.el index 36797fc6fdb..516e4f9cd63 100644 --- a/lisp/progmodes/elisp-mode.el +++ b/lisp/progmodes/elisp-mode.el @@ -1571,14 +1571,12 @@ In the absence of INDEX, just call `eldoc-docstring-format-sym-doc'." ;; Return a list of current function name and argument index. (defun elisp--fnsym-in-current-sexp () (save-excursion - (let ((argument-index (1- (elisp--beginning-of-sexp)))) - ;; If we are at the beginning of function name, this will be -1. - (when (< argument-index 0) - (setq argument-index 0)) - ;; Don't do anything if current word is inside a string. - (if (= (or (char-after (1- (point))) 0) ?\") - nil - (list (elisp--current-symbol) argument-index))))) + (unless (nth 8 (syntax-ppss)) + (let ((argument-index (1- (elisp--beginning-of-sexp)))) + ;; If we are at the beginning of function name, this will be -1. + (when (< argument-index 0) + (setq argument-index 0)) + (list (elisp--current-symbol) argument-index))))) ;; Move to the beginning of current sexp. Return the number of nested ;; sexp the point was over or after.