From 914b40da4ad01afd8b5a08e9e67001700bd1221a Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Mon, 13 Jan 2003 08:07:18 +0000 Subject: [PATCH] (apropos-documentation-property): New function. (apropos): Use apropos-documentation-property. --- lisp/apropos.el | 39 +++++++++++++++++++-------------------- 1 file changed, 19 insertions(+), 20 deletions(-) diff --git a/lisp/apropos.el b/lisp/apropos.el index 9a5230eaabf..159ad669d3e 100644 --- a/lisp/apropos.el +++ b/lisp/apropos.el @@ -432,6 +432,14 @@ satisfy the predicate VAR-PREDICATE." ;;;###autoload +(defun apropos-documentation-property (symbol property raw) + "Like (documentation-property SYMBOL PROPERTY RAW) but handle errors." + (condition-case () + (let ((doc (documentation-property symbol property raw))) + (if doc (substring doc 0 (string-match "\n" doc)) + "(not documented)")) + (error "(error retrieving documentation)"))) + (defun apropos (apropos-regexp &optional do-all) "Show all bound symbols whose names match APROPOS-REGEXP. With optional prefix DO-ALL or if `apropos-do-all' is non-nil, also @@ -463,37 +471,28 @@ time-consuming. Returns list of symbols and documentation found." (if (setq doc (condition-case nil (documentation symbol t) (void-function - "(alias for undefined function)"))) + "(alias for undefined function)") + (error + "(error retrieving function documentation"))) (substring doc 0 (string-match "\n" doc)) "(not documented)")) (when (boundp symbol) - (if (setq doc (documentation-property - symbol 'variable-documentation t)) - (substring doc 0 (string-match "\n" doc)) - "(not documented)")) + (apropos-documentation-property + symbol 'variable-documentation t)) (when (setq properties (symbol-plist symbol)) (setq doc (list (car properties))) (while (setq properties (cdr (cdr properties))) (setq doc (cons (car properties) doc))) (mapconcat #'symbol-name (nreverse doc) " ")) (when (get symbol 'widget-type) - (if (setq doc (documentation-property - symbol 'widget-documentation t)) - (substring doc 0 - (string-match "\n" doc)) - "(not documented)")) + (apropos-documentation-property + symbol 'widget-documentation t)) (when (facep symbol) - (if (setq doc (documentation-property - symbol 'face-documentation t)) - (substring doc 0 - (string-match "\n" doc)) - "(not documented)")) + (apropos-documentation-property + symbol 'face-documentation t)) (when (get symbol 'custom-group) - (if (setq doc (documentation-property - symbol 'group-documentation t)) - (substring doc 0 - (string-match "\n" doc)) - "(not documented)")))) + (apropos-documentation-property + symbol 'group-documentation t)))) (setq p (cdr p)))) (apropos-print (or do-all apropos-do-all) -- 2.39.2