# HG changeset patch # User Stefan Monnier # Date 1044913950 0 # Node ID e2f33e589249eefc49fe4f0e6b24689eb484b1fe # Parent 278d7d142185a0e0ab8bf5a233465692449722c9 (help-xref-on-pp): Only add xref if the text is less than 5K. diff -r 278d7d142185 -r e2f33e589249 lisp/help-mode.el --- a/lisp/help-mode.el Mon Feb 10 21:50:00 2003 +0000 +++ b/lisp/help-mode.el Mon Feb 10 21:52:30 2003 +0000 @@ -443,31 +443,29 @@ ;;;###autoload (defun help-xref-on-pp (from to) "Add xrefs for symbols in `pp's output between FROM and TO." - (let ((ost (syntax-table))) - (unwind-protect - (save-excursion - (save-restriction - (set-syntax-table emacs-lisp-mode-syntax-table) - (narrow-to-region from to) - (goto-char (point-min)) - (condition-case nil - (while (not (eobp)) - (cond - ((looking-at "\"") (forward-sexp 1)) - ((looking-at "#<") (search-forward ">" nil 'move)) - ((looking-at "\\(\\(\\sw\\|\\s_\\)+\\)") - (let* ((sym (intern-soft (match-string 1))) - (type (cond ((fboundp sym) 'help-function) - ((or (memq sym '(t nil)) - (keywordp sym)) - nil) - ((and sym (boundp sym)) - 'help-variable)))) - (when type (help-xref-button 1 type sym))) - (goto-char (match-end 1))) - (t (forward-char 1)))) - (error nil)))) - (set-syntax-table ost)))) + (if (> (- to from) 5000) nil + (with-syntax-table emacs-lisp-mode-syntax-table + (save-excursion + (save-restriction + (narrow-to-region from to) + (goto-char (point-min)) + (condition-case nil + (while (not (eobp)) + (cond + ((looking-at "\"") (forward-sexp 1)) + ((looking-at "#<") (search-forward ">" nil 'move)) + ((looking-at "\\(\\(\\sw\\|\\s_\\)+\\)") + (let* ((sym (intern-soft (match-string 1))) + (type (cond ((fboundp sym) 'help-function) + ((or (memq sym '(t nil)) + (keywordp sym)) + nil) + ((and sym (boundp sym)) + 'help-variable)))) + (when type (help-xref-button 1 type sym))) + (goto-char (match-end 1))) + (t (forward-char 1)))) + (error nil))))))) ;; Additional functions for (re-)creating types of help buffers.