]> git.eshelyaron.com Git - emacs.git/commitdiff
* lisp/emacs-lisp/eldoc.el (eldoc--supported-p): Understand the "old" API
authorStefan Monnier <monnier@iro.umontreal.ca>
Thu, 12 Mar 2020 15:18:07 +0000 (11:18 -0400)
committerStefan Monnier <monnier@iro.umontreal.ca>
Thu, 12 Mar 2020 15:18:07 +0000 (11:18 -0400)
lisp/emacs-lisp/eldoc.el

index 6e35018b100c901db8dc350d39735be0fe38f9d5..660fce4be0b5dca8e2f89f5e4c954d564433a781 100644 (file)
@@ -404,7 +404,16 @@ effect."
 (defun eldoc--supported-p ()
   "Non-nil if an ElDoc function is set for this buffer."
   (and (not (memq eldoc-documentation-function '(nil ignore)))
-       eldoc-documentation-functions))
+       (or eldoc-documentation-functions
+           ;; The old API had major modes set `eldoc-documentation-function'
+           ;; to provide eldoc support.  It's impossible now to determine
+           ;; reliably whether the `eldoc-documentation-function' provides
+           ;; eldoc support (as in the old API) or whether it just provides
+           ;; a way to combine the results of the
+           ;; `eldoc-documentation-functions' (as in the new API).
+           ;; But at least if it's set buffer-locally it's a good hint that
+           ;; there's some eldoc support in the current buffer.
+           (local-variable-p 'eldoc-documentation-function))))
 
 (defun eldoc-print-current-symbol-info ()
   "Print the text produced by `eldoc-documentation-function'."