# HG changeset patch # User Glenn Morris # Date 1218596845 0 # Node ID 569276db9359b9ef419e0344199045f89d472346 # Parent 9cdccb5e49a87be02ccaabafedb06e35da2cf50a (sync from trunk 2008-01-25) Martin Rudalics (find-library): Wrap search for library name in condition-case to avoid reporting a scan-error. (Bug#563) diff -r 9cdccb5e49a8 -r 569276db9359 lisp/emacs-lisp/find-func.el --- a/lisp/emacs-lisp/find-func.el Tue Aug 12 22:23:30 2008 +0000 +++ b/lisp/emacs-lisp/find-func.el Wed Aug 13 03:07:25 2008 +0000 @@ -198,11 +198,17 @@ (let* ((path (cons (or find-function-source-path load-path) (find-library-suffixes))) (def (if (eq (function-called-at-point) 'require) - (save-excursion - (backward-up-list) - (forward-char) - (backward-sexp -2) - (thing-at-point 'symbol)) + ;; `function-called-at-point' may return 'require + ;; with `point' anywhere on this line. So wrap the + ;; `save-excursion' below in a `condition-case' to + ;; avoid reporting a scan-error here. + (condition-case nil + (save-excursion + (backward-up-list) + (forward-char) + (forward-sexp 2) + (thing-at-point 'symbol)) + (error nil)) (thing-at-point 'symbol)))) (when def (setq def (and (locate-file-completion def path 'test) def)))