Mercurial > emacs
changeset 41600:037ba6ecc02a
(describe-categories, help-describe-category-set): New.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Tue, 27 Nov 2001 00:26:41 +0000 |
parents | 89445d205fb8 |
children | a1e88846ab9a |
files | lisp/help-fns.el |
diffstat | 1 files changed, 31 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/help-fns.el Tue Nov 27 00:07:33 2001 +0000 +++ b/lisp/help-fns.el Tue Nov 27 00:26:41 2001 +0000 @@ -452,6 +452,37 @@ (insert "\nThe parent syntax table is:") (describe-vector table 'internal-describe-syntax-value)))))) +(defun help-describe-category-set (value) + (insert (cond + ((null value) "default") + ((char-table-p value) "deeper char-table ...") + (t (condition-case err + (category-set-mnemonics value) + (error "invalid")))))) + +;;;###autoload +(defun describe-categories (&optional buffer) + "Describe the category specifications in the current category table. +The descriptions are inserted in a buffer, which is then displayed." + (interactive) + (setq buffer (or buffer (current-buffer))) + (help-setup-xref (list #'describe-categories buffer) (interactive-p)) + (with-output-to-temp-buffer (help-buffer) + (let ((table (with-current-buffer buffer (category-table)))) + (with-current-buffer standard-output + (describe-vector table 'help-describe-category-set) + (let ((docs (char-table-extra-slot table 0))) + (if (or (not (vectorp docs)) (/= (length docs) 95)) + (insert "Invalid first extra slot in this char table\n") + (insert "Meanings of mnemonic characters are:\n") + (dotimes (i 95) + (let ((elt (aref docs i))) + (when elt + (insert (+ i ?\ ) ": " elt "\n")))) + (while (setq table (char-table-parent table)) + (insert "\nThe parent category table is:") + (describe-vector table 'help-describe-category-set)))))))) + (provide 'help-fns) ;;; help-fns.el ends here