annotate lisp/descr-text.el @ 102438:c9e4d48261ce

*** empty log message ***
author Eli Zaretskii <eliz@gnu.org>
date Sat, 07 Mar 2009 13:31:35 +0000
parents c63836b5986a
children bd89d8afd5eb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
45057
1344a9d40dc8 Follow coding conventions.
Pavel Janík <Pavel@Janik.cz>
parents: 45022
diff changeset
1 ;;; descr-text.el --- describe text mode
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2
64762
41bb365f41c4 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64636
diff changeset
3 ;; Copyright (C) 1994, 1995, 1996, 2001, 2002, 2003, 2004,
100908
a9dc0e7c3f2b Add 2009 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 99817
diff changeset
4 ;; 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6 ;; Author: Boris Goldowsky <boris@gnu.org>
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
7 ;; Maintainer: FSF
59752
719482868b87 Add more keywords.
Eli Zaretskii <eliz@gnu.org>
parents: 58994
diff changeset
8 ;; Keywords: faces, i18n, Unicode, multilingual
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10 ;; This file is part of GNU Emacs.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94147
diff changeset
12 ;; GNU Emacs is free software: you can redistribute it and/or modify
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 ;; it under the terms of the GNU General Public License as published by
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94147
diff changeset
14 ;; the Free Software Foundation, either version 3 of the License, or
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94147
diff changeset
15 ;; (at your option) any later version.
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
16
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
17 ;; GNU Emacs is distributed in the hope that it will be useful,
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
20 ;; GNU General Public License for more details.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22 ;; You should have received a copy of the GNU General Public License
94678
ee5932bf781d Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94147
diff changeset
23 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25 ;;; Commentary:
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27 ;;; Describe-Text Mode.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29 ;;; Code:
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
31 (eval-when-compile (require 'quail))
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
32 (require 'help-fns)
51127
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
33
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34 ;;; Describe-Text Utilities.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36 (defun describe-text-widget (widget)
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37 "Insert text to describe WIDGET in the current buffer."
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
38 (insert-text-button
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
39 (symbol-name (if (symbolp widget) widget (car widget)))
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
40 'action `(lambda (&rest ignore)
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
41 (widget-browse ',widget))
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
42 'help-echo "mouse-2, RET: browse this widget")
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
43 (insert " ")
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
44 (insert-text-button
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
45 "(widget)Top" 'type 'help-info 'help-args '("(widget)Top")))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47 (defun describe-text-sexp (sexp)
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 "Insert a short description of SEXP in the current buffer."
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49 (let ((pp (condition-case signal
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 (pp-to-string sexp)
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51 (error (prin1-to-string signal)))))
95455
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
52 (when (string-match-p "\n\\'" pp)
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
53 (setq pp (substring pp 0 (1- (length pp)))))
95455
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
54
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
55 (if (and (not (string-match-p "\n" pp))
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
56 (<= (length pp) (- (window-width) (current-column))))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
57 (insert pp)
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
58 (insert-text-button
67865
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
59 "[Show]" 'action `(lambda (&rest ignore)
95455
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
60 (with-output-to-temp-buffer
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
61 "*Pp Eval Output*"
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
62 (princ ',pp)))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
63 'help-echo "mouse-2, RET: pretty print value in another buffer"))))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
64
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
65 (defun describe-property-list (properties)
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
66 "Insert a description of PROPERTIES in the current buffer.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67 PROPERTIES should be a list of overlay or text properties.
54686
d74ae0505dad (describe-property-list): Add `font-lock-face'.
Juri Linkov <juri@jurta.org>
parents: 54545
diff changeset
68 The `category', `face' and `font-lock-face' properties are made
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
69 into help buttons that call `describe-text-category' or
54686
d74ae0505dad (describe-property-list): Add `font-lock-face'.
Juri Linkov <juri@jurta.org>
parents: 54545
diff changeset
70 `describe-face' when pushed."
45697
234b16d90545 (describe-text-properties): Sort the output by the size of the values.
Colin Walters <walters@gnu.org>
parents: 45057
diff changeset
71 ;; Sort the properties by the size of their value.
58994
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
72 (dolist (elt (sort (let (ret)
45697
234b16d90545 (describe-text-properties): Sort the output by the size of the values.
Colin Walters <walters@gnu.org>
parents: 45057
diff changeset
73 (while properties
58994
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
74 (push (list (pop properties) (pop properties)) ret))
45697
234b16d90545 (describe-text-properties): Sort the output by the size of the values.
Colin Walters <walters@gnu.org>
parents: 45057
diff changeset
75 ret)
65376
22f4c45c6f2f (describe-property-list): Handle non-symbol prop names.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
76 (lambda (a b) (string< (prin1-to-string (nth 0 a) t)
22f4c45c6f2f (describe-property-list): Handle non-symbol prop names.
Richard M. Stallman <rms@gnu.org>
parents: 64762
diff changeset
77 (prin1-to-string (nth 0 b) t)))))
45697
234b16d90545 (describe-text-properties): Sort the output by the size of the values.
Colin Walters <walters@gnu.org>
parents: 45057
diff changeset
78 (let ((key (nth 0 elt))
234b16d90545 (describe-text-properties): Sort the output by the size of the values.
Colin Walters <walters@gnu.org>
parents: 45057
diff changeset
79 (value (nth 1 elt)))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
80 (insert (propertize (format " %-20s " key)
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
81 'face 'help-argument-name))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82 (cond ((eq key 'category)
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
83 (insert-text-button
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
84 (symbol-name value)
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
85 'action `(lambda (&rest ignore)
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
86 (describe-text-category ',value))
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
87 'help-echo "mouse-2, RET: describe this category"))
58994
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
88 ((memq key '(face font-lock-face mouse-face))
67865
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
89 (insert-text-button
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
90 (format "%S" value)
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
91 'type 'help-face 'help-args (list value)))
55754
da7a694d2097 (describe-property-list): Add [show] button for
Juri Linkov <juri@jurta.org>
parents: 55584
diff changeset
92 ((widgetp value)
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
93 (describe-text-widget value))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94 (t
58994
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
95 (describe-text-sexp value))))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
96 (insert "\n")))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
97
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
98 ;;; Describe-Text Commands.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 (defun describe-text-category (category)
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101 "Describe a text property category."
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
102 (interactive "SCategory: ")
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
103 (help-setup-xref (list #'describe-text-category category) (interactive-p))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104 (save-excursion
47601
7d00d911e8b9 (describe-text-category): Use *Help*. Don't kill-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47379
diff changeset
105 (with-output-to-temp-buffer "*Help*"
7d00d911e8b9 (describe-text-category): Use *Help*. Don't kill-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47379
diff changeset
106 (set-buffer standard-output)
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
107 (insert "Category " (format "%S" category) ":\n\n")
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
108 (describe-property-list (symbol-plist category))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
109 (goto-char (point-min)))))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
110
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
111 ;;;###autoload
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
112 (defun describe-text-properties (pos &optional output-buffer)
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
113 "Describe widgets, buttons, overlays and text properties at POS.
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
114 Interactively, describe them for the character after point.
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
115 If optional second argument OUTPUT-BUFFER is non-nil,
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
116 insert the output into that buffer, and don't initialize or clear it
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
117 otherwise."
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
118 (interactive "d")
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
119 (if (>= pos (point-max))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
120 (error "No character follows specified position"))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
121 (if output-buffer
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
122 (describe-text-properties-1 pos output-buffer)
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
123 (if (not (or (text-properties-at pos) (overlays-at pos)))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
124 (message "This is plain text.")
57857
6d1cf277e127 (describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents: 57181
diff changeset
125 (let ((buffer (current-buffer))
6d1cf277e127 (describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents: 57181
diff changeset
126 (target-buffer "*Help*"))
6d1cf277e127 (describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents: 57181
diff changeset
127 (when (eq buffer (get-buffer target-buffer))
67559
da1c54077c04 (describe-text-properties): Replace buffer name "*Help-2*" with "*Help*<2>".
Juri Linkov <juri@jurta.org>
parents: 67542
diff changeset
128 (setq target-buffer "*Help*<2>"))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
129 (save-excursion
57857
6d1cf277e127 (describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents: 57181
diff changeset
130 (with-output-to-temp-buffer target-buffer
47601
7d00d911e8b9 (describe-text-category): Use *Help*. Don't kill-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47379
diff changeset
131 (set-buffer standard-output)
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
132 (setq output-buffer (current-buffer))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
133 (insert "Text content at position " (format "%d" pos) ":\n\n")
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
134 (with-current-buffer buffer
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
135 (describe-text-properties-1 pos output-buffer))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
136 (goto-char (point-min))))))))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
137
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
138 (defun describe-text-properties-1 (pos output-buffer)
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
139 (let* ((properties (text-properties-at pos))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
140 (overlays (overlays-at pos))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
141 (wid-field (get-char-property pos 'field))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
142 (wid-button (get-char-property pos 'button))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
143 (wid-doc (get-char-property pos 'widget-doc))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144 ;; If button.el is not loaded, we have no buttons in the text.
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
145 (button (and (fboundp 'button-at) (button-at pos)))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
146 (button-type (and button (button-type button)))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
147 (button-label (and button (button-label button)))
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
148 (widget (or wid-field wid-button wid-doc)))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
149 (with-current-buffer output-buffer
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
150 ;; Widgets
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
151 (when (widgetp widget)
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
152 (newline)
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
153 (insert (cond (wid-field "This is an editable text area")
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
154 (wid-button "This is an active area")
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
155 (wid-doc "This is documentation text")))
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
156 (insert " of a ")
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
157 (describe-text-widget widget)
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
158 (insert ".\n\n"))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
159 ;; Buttons
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
160 (when (and button (not (widgetp wid-button)))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
161 (newline)
67865
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
162 (insert "Here is a `" (format "%S" button-type)
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
163 "' button labeled `" button-label "'.\n\n"))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
164 ;; Overlays
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
165 (when overlays
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
166 (newline)
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
167 (if (eq (length overlays) 1)
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
168 (insert "There is an overlay here:\n")
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
169 (insert "There are " (format "%d" (length overlays))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
170 " overlays here:\n"))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
171 (dolist (overlay overlays)
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
172 (insert " From " (format "%d" (overlay-start overlay))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
173 " to " (format "%d" (overlay-end overlay)) "\n")
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
174 (describe-property-list (overlay-properties overlay)))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
175 (insert "\n"))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
176 ;; Text properties
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
177 (when properties
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
178 (newline)
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
179 (insert "There are text properties here:\n")
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
180 (describe-property-list properties)))))
51278
7192dc1bfcf4 (describe-char-unicode-data): New dummy definition.
Richard M. Stallman <rms@gnu.org>
parents: 51127
diff changeset
181
96754
79e210b5bd7b (describe-char-unidata-list): Initialize to the
Kenichi Handa <handa@m17n.org>
parents: 96416
diff changeset
182 (defcustom describe-char-unidata-list
99817
a5a1e57fb667 (describe-char-unidata-list): Move `old-name' to be immediately after `name'.
Juri Linkov <juri@jurta.org>
parents: 99151
diff changeset
183 '(name old-name general-category decomposition)
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
184 "List of Unicode-based character property names shown by `describe-char'."
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
185 :group 'mule
90104
a01e7a9f1659 Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-14
Miles Bader <miles@gnu.org>
parents: 90103
diff changeset
186 :version "23.1"
93054
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
187 :type '(choice (const :tag "All properties" t)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
188 (set
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
189 (const :tag "Unicode Name" name)
99817
a5a1e57fb667 (describe-char-unidata-list): Move `old-name' to be immediately after `name'.
Juri Linkov <juri@jurta.org>
parents: 99151
diff changeset
190 (const :tag "Unicode old name" old-name)
93054
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
191 (const :tag "Unicode general category " general-category)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
192 (const :tag "Unicode canonical combining class"
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
193 canonical-combining-class)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
194 (const :tag "Unicode bidi class" bidi-class)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
195 (const :tag "Unicode decomposition mapping" decomposition)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
196 (const :tag "Unicode decimal digit value" decimal-digit-value)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
197 (const :tag "Unicode digit value" digit-value)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
198 (const :tag "Unicode numeric value" numeric-value)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
199 (const :tag "Unicode mirrored" mirrored)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
200 (const :tag "Unicode ISO 10646 comment" iso-10646-comment)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
201 (const :tag "Unicode simple uppercase mapping" uppercase)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
202 (const :tag "Unicode simple lowercase mapping" lowercase)
ca8b9e092766 (describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91335
diff changeset
203 (const :tag "Unicode simple titlecase mapping" titlecase))))
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
204
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
205 (defcustom describe-char-unicodedata-file nil
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
206 "Location of Unicode data file.
74356
25c9571827a2 *** empty log message ***
Juanma Barranquero <lekktu@gmail.com>
parents: 68651
diff changeset
207 This is the UnicodeData.txt file from the Unicode Consortium, used for
59758
b8352a1f354a (describe-char-unicodedata-file): Docstring fix.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 59752
diff changeset
208 diagnostics. If it is non-nil `describe-char' will print data
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
209 looked up from it. This facility is mostly of use to people doing
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
210 multilingual development.
51127
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
211
74356
25c9571827a2 *** empty log message ***
Juanma Barranquero <lekktu@gmail.com>
parents: 68651
diff changeset
212 This is a fairly large file, not typically present on GNU systems.
25c9571827a2 *** empty log message ***
Juanma Barranquero <lekktu@gmail.com>
parents: 68651
diff changeset
213 At the time of writing it is at the URL
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
214 `http://www.unicode.org/Public/UNIDATA/UnicodeData.txt'."
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
215 :group 'mule
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 59758
diff changeset
216 :version "22.1"
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
217 :type '(choice (const :tag "None" nil)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
218 file))
51278
7192dc1bfcf4 (describe-char-unicode-data): New dummy definition.
Richard M. Stallman <rms@gnu.org>
parents: 51127
diff changeset
219
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
220 (defun describe-char-unicode-data (char)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
221 "Return a list of Unicode data for unicode CHAR.
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
222 Each element is a list of a property description and the property value.
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
223 The list is null if CHAR isn't found in `describe-char-unicodedata-file'.
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
224 This function is semi-obsolete. Use `get-char-code-property'."
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
225 (when describe-char-unicodedata-file
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
226 (unless (file-exists-p describe-char-unicodedata-file)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
227 (error "`unicodedata-file' %s not found" describe-char-unicodedata-file))
74403
04f1edde004d (describe-char-unicode-data): Use a hidden buffer for Unicode data file pointed
Juanma Barranquero <lekktu@gmail.com>
parents: 74356
diff changeset
228 (with-current-buffer (get-buffer-create " *Unicode Data*")
04f1edde004d (describe-char-unicode-data): Use a hidden buffer for Unicode data file pointed
Juanma Barranquero <lekktu@gmail.com>
parents: 74356
diff changeset
229 (when (zerop (buffer-size))
04f1edde004d (describe-char-unicode-data): Use a hidden buffer for Unicode data file pointed
Juanma Barranquero <lekktu@gmail.com>
parents: 74356
diff changeset
230 ;; Don't use -literally in case of DOS line endings.
04f1edde004d (describe-char-unicode-data): Use a hidden buffer for Unicode data file pointed
Juanma Barranquero <lekktu@gmail.com>
parents: 74356
diff changeset
231 (insert-file-contents describe-char-unicodedata-file))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
232 (goto-char (point-min))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
233 (let ((hex (format "%04X" char))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
234 found first last)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
235 (if (re-search-forward (concat "^" hex) nil t)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
236 (setq found t)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
237 ;; It's not listed explicitly. Look for ranges, e.g. CJK
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
238 ;; ideographs, and check whether it's in one of them.
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
239 (while (and (re-search-forward "^\\([^;]+\\);[^;]+First>;" nil t)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
240 (>= char (setq first
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
241 (string-to-number (match-string 1) 16)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
242 (progn
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
243 (forward-line 1)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
244 (looking-at "^\\([^;]+\\);[^;]+Last>;")
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
245 (> char
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
246 (setq last
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
247 (string-to-number (match-string 1) 16))))))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
248 (if (and (>= char first)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
249 (<= char last))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
250 (setq found t)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
251 (if found
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
252 (let ((fields (mapcar (lambda (elt)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
253 (if (> (length elt) 0)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
254 elt))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
255 (cdr (split-string
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
256 (buffer-substring
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
257 (line-beginning-position)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
258 (line-end-position))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
259 ";")))))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
260 ;; The length depends on whether the last field was empty.
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
261 (unless (or (= 13 (length fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
262 (= 14 (length fields)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
263 (error "Invalid contents in %s" describe-char-unicodedata-file))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
264 ;; The field names and values lists are slightly
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
265 ;; modified from Mule-UCS unidata.el.
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
266 (list
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
267 (list "Name" (let ((name (nth 0 fields)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
268 ;; Check for <..., First>, <..., Last>
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
269 (if (string-match "\\`\\(<[^,]+\\)," name)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
270 (concat (match-string 1 name) ">")
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
271 name)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
272 (list "Category"
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
273 (let ((val (nth 1 fields)))
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
274 (or (char-code-property-description
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
275 'general-category (intern val))
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
276 val)))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
277 (list "Combining class"
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
278 (let ((val (nth 1 fields)))
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
279 (or (char-code-property-description
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
280 'canonical-combining-class (intern val))
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
281 val)))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
282 (list "Bidi category"
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
283 (let ((val (nth 1 fields)))
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
284 (or (char-code-property-description
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
285 'bidi-class (intern val))
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
286 val)))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
287 (list
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
288 "Decomposition"
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
289 (if (nth 4 fields)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
290 (let* ((parts (split-string (nth 4 fields)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
291 (info (car parts)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
292 (if (string-match "\\`<\\(.+\\)>\\'" info)
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
293 (setq info (match-string 1 info))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
294 (setq info nil))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
295 (if info (setq parts (cdr parts)))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
296 (setq parts (mapconcat
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
297 (lambda (arg)
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
298 (string (string-to-number arg 16)))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
299 parts " "))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
300 (concat info parts))))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
301 (list "Decimal digit value"
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
302 (nth 5 fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
303 (list "Digit value"
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
304 (nth 6 fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
305 (list "Numeric value"
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
306 (nth 7 fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
307 (list "Mirrored"
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
308 (if (equal "Y" (nth 8 fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
309 "yes"))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
310 (list "Old name" (nth 9 fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
311 (list "ISO 10646 comment" (nth 10 fields))
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
312 (list "Uppercase" (and (nth 11 fields)
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
313 (string (string-to-number
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
314 (nth 11 fields) 16))))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
315 (list "Lowercase" (and (nth 12 fields)
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
316 (string (string-to-number
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
317 (nth 12 fields) 16))))
55584
bdbbd721cc67 (describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 55543
diff changeset
318 (list "Titlecase" (and (nth 13 fields)
90087
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
319 (string (string-to-number
230281e520b3 (describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90085
diff changeset
320 (nth 13 fields) 16)))))))))))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
321
95841
b4e36ff621b3 Add some compiler declarations, for builds without X.
Glenn Morris <rgm@gnu.org>
parents: 95455
diff changeset
322 ;; Not defined on builds without X, but behind display-graphic-p.
b4e36ff621b3 Add some compiler declarations, for builds without X.
Glenn Morris <rgm@gnu.org>
parents: 95455
diff changeset
323 (declare-function internal-char-font "fontset.c" (position &optional ch))
b4e36ff621b3 Add some compiler declarations, for builds without X.
Glenn Morris <rgm@gnu.org>
parents: 95455
diff changeset
324
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
325 ;; Return information about how CHAR is displayed at the buffer
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
326 ;; position POS. If the selected frame is on a graphic display,
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
327 ;; return a string "FONT-DRIVER:FONT-NAME (GLYPH-CODE)" where:
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
328 ;; FONT-DRIVER is the font-driver name,
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
329 ;; FONT-NAME is the font name,
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
330 ;; GLYPH-CODE is a hexadigit string representing the glyph-ID.
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
331 ;; Otherwise, return a string describing the terminal codes for the
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
332 ;; character.
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
333 (defun describe-char-display (pos char)
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
334 (if (display-graphic-p (selected-frame))
91328
f64f6ef4cdfe (describe-char-display): Convert a GLYPH-CODE to a
Kenichi Handa <handa@m17n.org>
parents: 91327
diff changeset
335 (let ((char-font-info (internal-char-font pos char)))
91335
07ce8496076f (describe-char-display): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 91328
diff changeset
336 (if char-font-info
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
337 (let ((type (font-get (car char-font-info) :type))
97005
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
338 (name (font-xlfd-name (car char-font-info)))
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
339 (code (cdr char-font-info)))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
340 (if (integerp code)
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
341 (format "%s:%s (#x%02X)" type name code)
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
342 (format "%s:%s (#x%04X%04X)"
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
343 type name (car code) (cdr code))))))
97196
15d4d10ad710 (describe-char-display): Call encode-coding-char
Kenichi Handa <handa@m17n.org>
parents: 97005
diff changeset
344 (let* ((charset (get-text-property pos 'charset))
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
345 (coding (or (terminal-coding-system) 'us-ascii))
97196
15d4d10ad710 (describe-char-display): Call encode-coding-char
Kenichi Handa <handa@m17n.org>
parents: 97005
diff changeset
346 (encoded (encode-coding-char char coding charset)))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
347 (if encoded
97259
067d03b2ec89 * descr-text.el (describe-char-display): Fix last change:
Juanma Barranquero <lekktu@gmail.com>
parents: 97196
diff changeset
348 (encoded-string-description encoded coding)))))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
349
51278
7192dc1bfcf4 (describe-char-unicode-data): New dummy definition.
Richard M. Stallman <rms@gnu.org>
parents: 51127
diff changeset
350
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
351 ;; Return a string of CH with composition for padding on both sides.
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
352 ;; It is displayed without overlapping with the left/right columns.
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
353 (defsubst describe-char-padded-string (ch)
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
354 (compose-string (string ch) 0 1 (format "\t%c\t" ch)))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
355
101290
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
356 ;; Return a nicely formated list of categories; extended category
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
357 ;; description is added to the category name as a tooltip
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
358 (defsubst describe-char-categories (category-set)
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
359 (let ((mnemonics (category-set-mnemonics category-set)))
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
360 (unless (eq mnemonics "")
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
361 (list (mapconcat
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
362 #'(lambda (x)
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
363 (let* ((c (category-docstring x))
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
364 (doc (if (string-match "\\`\\(.*?\\)\n\\(.*\\)\\'" c)
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
365 (propertize (match-string 1 c)
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
366 'help-echo (match-string 2 c))
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
367 c)))
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
368 (format "%c:%s" x doc)))
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
369 mnemonics ", ")))))
017ab5339c4c * descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents: 100908
diff changeset
370
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
371 ;;;###autoload
67855
d6290d5c2df4 (describe-char): Set help-xref-stack-item
Nick Roberts <nickrob@snap.net.nz>
parents: 67815
diff changeset
372 (defun describe-char (pos)
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
373 "Describe the character after POS (interactively, the character after point).
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
374 The information includes character code, charset and code points in it,
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
375 syntax, category, how the character is encoded in a file,
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
376 character composition information (if relevant),
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
377 as well as widgets, buttons, overlays, and text properties."
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
378 (interactive "d")
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
379 (if (>= pos (point-max))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
380 (error "No character follows specified position"))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
381 (let* ((char (char-after pos))
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
382 (eight-bit-p (and (not enable-multibyte-characters) (>= char 128)))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
383 (charset (if eight-bit-p 'eight-bit
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
384 (or (get-text-property pos 'charset) (char-charset char))))
47601
7d00d911e8b9 (describe-text-category): Use *Help*. Don't kill-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47379
diff changeset
385 (composition (find-composition pos nil nil t))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
386 (component-chars nil)
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
387 (display-table (or (window-display-table)
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
388 buffer-display-table
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
389 standard-display-table))
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
390 (disp-vector (and display-table (aref display-table char)))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
391 (multibyte-p enable-multibyte-characters)
55305
b1c52f4076c4 (describe-char): Copy the character with text
Kenichi Handa <handa@m17n.org>
parents: 55036
diff changeset
392 (overlays (mapcar #'(lambda (o) (overlay-properties o))
b1c52f4076c4 (describe-char): Copy the character with text
Kenichi Handa <handa@m17n.org>
parents: 55036
diff changeset
393 (overlays-at pos)))
67050
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
394 (char-description (if (not multibyte-p)
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
395 (single-key-description char)
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
396 (if (< char 128)
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
397 (single-key-description char)
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
398 (string-to-multibyte
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
399 (char-to-string char)))))
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
400 (text-props-desc
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
401 (let ((tmp-buf (generate-new-buffer " *text-props*")))
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
402 (unwind-protect
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
403 (progn
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
404 (describe-text-properties pos tmp-buf)
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
405 (with-current-buffer tmp-buf (buffer-string)))
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
406 (kill-buffer tmp-buf))))
89943
4c90ffeb71c5 Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15
Miles Bader <miles@gnu.org>
parents: 89921 55754
diff changeset
407 item-list max-width code)
51127
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
408
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
409 (if multibyte-p
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
410 (or (setq code (encode-char char charset))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
411 (setq charset (char-charset char)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
412 code (encode-char char charset)))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
413 (setq code char))
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
414 (when composition
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
415 ;; When the composition is trivial (i.e. composed only with the
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
416 ;; current character itself without any alternate characters),
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
417 ;; we don't show the composition information. Otherwise, store
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
418 ;; two descriptive strings in the first two elments of
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
419 ;; COMPOSITION.
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
420 (or (catch 'tag
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
421 (let ((from (car composition))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
422 (to (nth 1 composition))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
423 (next (1+ pos))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
424 (components (nth 2 composition))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
425 ch)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
426 (if (and (vectorp components) (vectorp (aref components 0)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
427 (let ((idx (- pos from))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
428 (nglyphs (lgstring-glyph-len components))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
429 (i 0) j glyph glyph-from)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
430 ;; COMPONENTS is a gstring. Find a grapheme
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
431 ;; cluster containing the current character.
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
432 (while (and (< i nglyphs)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
433 (setq glyph (lgstring-glyph components i))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
434 (< (lglyph-to glyph) idx))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
435 (setq i (1+ i)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
436 (if (or (not glyph) (= i nglyphs))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
437 ;; The composition is broken.
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
438 (throw 'tag nil))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
439 (setq glyph-from (lglyph-from glyph)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
440 to (+ from (lglyph-to glyph) 1)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
441 from (+ from glyph-from)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
442 j i)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
443 (while (and (< j nglyphs)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
444 (setq glyph (lgstring-glyph components j))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
445 (= (lglyph-from glyph) glyph-from))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
446 (setq j (1+ j)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
447 (if (and (= i (1- j))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
448 (setq glyph (lgstring-glyph components i))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
449 (= char (lglyph-char glyph)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
450 ;; The composition is trivial.
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
451 (throw 'tag nil))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
452 (nconc composition (list i (1- j))))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
453 (dotimes (i (length components))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
454 (if (integerp (setq ch (aref components i)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
455 (push (cons ch (describe-char-display pos ch))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
456 component-chars)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
457 (setq component-chars (nreverse component-chars)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
458 (if (< from pos)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
459 (if (< (1+ pos) to)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
460 (setcar composition
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
461 (concat
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
462 " with the surrounding characters \""
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
463 (mapconcat 'describe-char-padded-string
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
464 (buffer-substring from pos) "")
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
465 "\" and \""
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
466 (mapconcat 'describe-char-padded-string
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
467 (buffer-substring (1+ pos) to) "")
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
468 "\""))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
469 (setcar composition
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
470 (concat
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
471 " with the preceding character(s) \""
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
472 (mapconcat 'describe-char-padded-string
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
473 (buffer-substring from pos) "")
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
474 "\"")))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
475 (if (< (1+ pos) to)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
476 (setcar composition
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
477 (concat
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
478 " with the following character(s) \""
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
479 (mapconcat 'describe-char-padded-string
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
480 (buffer-substring (1+ pos) to) "")
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
481 "\""))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
482 (setcar composition nil)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
483 (setcar (cdr composition)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
484 (format "composed to form \"%s\" (see below)"
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
485 (buffer-substring from to)))))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
486 (setq composition nil)))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
487
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
488 (setq item-list
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
489 `(("character"
90261
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
490 ,(format "%s (%d, #o%o, #x%x)"
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
491 (apply 'propertize char-description
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
492 (text-properties-at pos))
90261
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
493 char char char))
89943
4c90ffeb71c5 Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15
Miles Bader <miles@gnu.org>
parents: 89921 55754
diff changeset
494 ("preferred charset"
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
495 ,`(insert-text-button
67814
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
496 ,(symbol-name charset)
cc79e7966f97 2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents: 67752
diff changeset
497 'type 'help-character-set 'help-args '(,charset))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
498 ,(format "(%s)" (charset-description charset)))
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
499 ("code point"
90215
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
500 ,(let ((str (if (integerp code)
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
501 (format (if (< code 256) "0x%02X" "0x%04X") code)
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
502 (format "0x%04X%04X" (car code) (cdr code)))))
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
503 (if (<= (charset-dimension charset) 2)
90261
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
504 `(insert-text-button
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
505 ,str
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
506 'action (lambda (&rest ignore)
90215
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
507 (list-charset-chars ',charset)
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
508 (with-selected-window
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
509 (get-buffer-window "*Character List*" 0)
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
510 (goto-char (point-min))
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
511 (forward-line 2) ;Skip the header.
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
512 (let ((case-fold-search nil))
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
513 (if (search-forward ,(char-to-string char)
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
514 nil t)
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
515 (goto-char (match-beginning 0))))))
90261
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
516 'help-echo
7beb78bc1f8e Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
parents: 90227 67865
diff changeset
517 "mouse-2, RET: show this character in its character set")
90215
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
518 str)))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
519 ("syntax"
58416
28906724d6e3 (syntax-after): Undo last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58150
diff changeset
520 ,(let ((syntax (syntax-after pos)))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
521 (with-temp-buffer
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
522 (internal-describe-syntax-value syntax)
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
523 (buffer-string))))
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
524 ("category"
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
525 ,@(if (not eight-bit-p)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
526 (let ((category-set (char-category-set char)))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
527 (if category-set
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
528 (describe-char-categories category-set)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
529 '("-- none --")))))
55543
7b6cb8aae6f3 Require quail at comile time.
Kenichi Handa <handa@m17n.org>
parents: 55491
diff changeset
530 ("to input"
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
531 ,@(if (not eight-bit-p)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
532 (let ((key-list (and (eq input-method-function
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
533 'quail-input-method)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
534 (quail-find-key char))))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
535 (if (consp key-list)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
536 (list "type"
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
537 (mapconcat #'(lambda (x) (concat "\"" x "\""))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
538 key-list " or ")
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
539 "with"
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
540 `(insert-text-button
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
541 ,current-input-method
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
542 'type 'help-input-method
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
543 'help-args '(,current-input-method)))))))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
544 ("buffer code"
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
545 ,(if multibyte-p
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
546 (encoded-string-description
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
547 (string-as-unibyte (char-to-string char)) nil)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
548 (format "#x%02X" char)))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
549 ("file code"
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
550 ,@(if multibyte-p
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
551 (let* ((coding buffer-file-coding-system)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
552 (encoded (encode-coding-char char coding charset)))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
553 (if encoded
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
554 (list (encoded-string-description encoded coding)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
555 (format "(encoded by coding system %S)" coding))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
556 (list "not encodable by coding system"
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
557 (symbol-name coding))))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
558 (list (format "#x%02X" char))))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
559 ("display"
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
560 ,(cond
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
561 (disp-vector
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
562 (setq disp-vector (copy-sequence disp-vector))
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
563 (dotimes (i (length disp-vector))
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
564 (aset disp-vector i
97005
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
565 (cons (aref disp-vector i)
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
566 (describe-char-display
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
567 pos (glyph-char (aref disp-vector i))))))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
568 (format "by display table entry [%s] (see below)"
58994
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
569 (mapconcat
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
570 #'(lambda (x)
75872
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
571 (format "?%c" (glyph-char (car x))))
58994
720c9b9bf376 (describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents: 58416
diff changeset
572 disp-vector " ")))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
573 (composition
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
574 (cadr composition))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
575 (t
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
576 (let ((display (describe-char-display pos char)))
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
577 (if (display-graphic-p (selected-frame))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
578 (if display
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
579 (concat "by this font (glyph code)\n " display)
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
580 "no font available")
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
581 (if display
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
582 (format "terminal code %s" display)
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
583 "not encodable for terminal"))))))
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
584 ,@(let ((face
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
585 (if (not (or disp-vector composition))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
586 (cond
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
587 ((and show-trailing-whitespace
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
588 (save-excursion (goto-char pos)
95455
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
589 (looking-at-p "[ \t]+$")))
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
590 'trailing-whitespace)
90215
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
591 ((and nobreak-char-display char (eq char '#xa0))
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
592 'nobreak-space)
90215
7217d5a385f8 (describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents: 90203
diff changeset
593 ((and nobreak-char-display char (eq char '#xad))
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
594 'escape-glyph)
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
595 ((and (< char 32) (not (memq char '(9 10))))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
596 'escape-glyph)))))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
597 (if face (list (list "hardcoded face"
67865
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
598 `(insert-text-button
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
599 ,(symbol-name face)
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
600 'type 'help-face 'help-args '(,face))))))
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
601 ,@(if (not eight-bit-p)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
602 (let ((unicodedata (describe-char-unicode-data char)))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
603 (if unicodedata
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
604 (cons (list "Unicode data" " ") unicodedata))))))
93058
273ed23a0a68 (describe-char): When specifying all properties,
Juanma Barranquero <lekktu@gmail.com>
parents: 93054
diff changeset
605 (setq max-width (apply #'max (mapcar #'(lambda (x)
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
606 (if (cadr x) (length (car x)) 0))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
607 item-list)))
67855
d6290d5c2df4 (describe-char): Set help-xref-stack-item
Nick Roberts <nickrob@snap.net.nz>
parents: 67815
diff changeset
608 (help-setup-xref nil (interactive-p))
86008
054e548612aa (describe-char): Use with-help-window instead of with-output-to-temp-buffer.
Martin Rudalics <rudalics@gmx.at>
parents: 78236
diff changeset
609 (with-help-window (help-buffer)
47601
7d00d911e8b9 (describe-text-category): Use *Help*. Don't kill-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 47379
diff changeset
610 (with-current-buffer standard-output
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
611 (set-buffer-multibyte multibyte-p)
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
612 (let ((formatter (format "%%%ds:" max-width)))
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
613 (dolist (elt item-list)
51127
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
614 (when (cadr elt)
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
615 (insert (format formatter (car elt)))
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
616 (dolist (clm (cdr elt))
67752
dd459879f1e7 Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents: 67559
diff changeset
617 (if (eq (car-safe clm) 'insert-text-button)
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
618 (progn (insert " ") (eval clm))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
619 (when (>= (+ (current-column)
95455
a11e3f3131cc (describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents: 94678
diff changeset
620 (or (string-match-p "\n" clm)
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
621 (string-width clm))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
622 1)
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
623 (window-width))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
624 (insert "\n")
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
625 (indent-to (1+ max-width)))
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
626 (insert " " clm)))
51127
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
627 (insert "\n"))))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
628
67371
0df745d01551 (describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents: 67050
diff changeset
629 (when overlays
0df745d01551 (describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents: 67050
diff changeset
630 (save-excursion
0df745d01551 (describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents: 67050
diff changeset
631 (goto-char (point-min))
0df745d01551 (describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents: 67050
diff changeset
632 (re-search-forward "character:[ \t\n]+")
97005
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
633 (let ((end (+ (point) (length char-description))))
67050
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
634 (mapc #'(lambda (props)
67371
0df745d01551 (describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents: 67050
diff changeset
635 (let ((o (make-overlay (point) end)))
67050
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
636 (while props
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
637 (overlay-put o (car props) (nth 1 props))
c365e04ea266 (describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents: 67035
diff changeset
638 (setq props (cddr props)))))
67371
0df745d01551 (describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents: 67050
diff changeset
639 overlays))))
55491
79abf8a72f5a (describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents: 55305
diff changeset
640
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
641 (when disp-vector
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
642 (insert
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
643 "\nThe display table entry is displayed by ")
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
644 (if (display-graphic-p (selected-frame))
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
645 (progn
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
646 (insert "these fonts (glyph codes):\n")
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
647 (dotimes (i (length disp-vector))
75872
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
648 (insert (glyph-char (car (aref disp-vector i))) ?:
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
649 (propertize " " 'display '(space :align-to 5))
97005
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
650 (or (cdr (aref disp-vector i)) "-- no font --")
64495
524cffc1c27d (describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents: 64091
diff changeset
651 "\n")
75872
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
652 (let ((face (glyph-face (car (aref disp-vector i)))))
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
653 (when face
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
654 (insert (propertize " " 'display '(space :align-to 5))
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
655 "face: ")
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
656 (insert (concat "`" (symbol-name face) "'"))
a527b46e9ab2 (describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents: 75347
diff changeset
657 (insert "\n")))))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
658 (insert "these terminal codes:\n")
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
659 (dotimes (i (length disp-vector))
54518
ee587e56fbc4 (describe-char): Use window-width instead of frame-width.
Juri Linkov <juri@jurta.org>
parents: 53028
diff changeset
660 (insert (car (aref disp-vector i))
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
661 (propertize " " 'display '(space :align-to 5))
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
662 (or (cdr (aref disp-vector i)) "-- not encodable --")
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
663 "\n"))))
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
664
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
665 (when composition
52655
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
666 (insert "\nComposed")
8d4e6d1d7201 (describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
667 (if (car composition)
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
668 (insert (car composition)))
91180
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
669 (if (and (vectorp (nth 2 composition))
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
670 (vectorp (aref (nth 2 composition) 0)))
97984
672009e514b4 (describe-char): Fix handling of automatic composition.
Kenichi Handa <handa@m17n.org>
parents: 97259
diff changeset
671 (let* ((gstring (nth 2 composition))
672009e514b4 (describe-char): Fix handling of automatic composition.
Kenichi Handa <handa@m17n.org>
parents: 97259
diff changeset
672 (font (lgstring-font gstring))
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
673 (from (nth 3 composition))
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
674 (to (nth 4 composition))
97984
672009e514b4 (describe-char): Fix handling of automatic composition.
Kenichi Handa <handa@m17n.org>
parents: 97259
diff changeset
675 glyph)
101781
7d00428842ae (describe-char): Check font-object by fontp.
Kenichi Handa <handa@m17n.org>
parents: 101304
diff changeset
676 (if (fontp font)
99151
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
677 (progn
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
678 (insert " using this font:\n "
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
679 (symbol-name (font-get font :type))
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
680 ?:
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
681 (aref (query-font font) 0)
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
682 "\nby these glyphs:\n")
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
683 (while (and (<= from to)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
684 (setq glyph (lgstring-glyph gstring from)))
99151
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
685 (insert (format " %S\n" glyph))
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
686 (setq from (1+ from))))
99151
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
687 (insert " by these characters:\n")
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
688 (while (and (<= from to)
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
689 (setq glyph (lgstring-glyph gstring from)))
99151
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
690 (insert (format " %c (#x%d)\n"
524569e0f990 (describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents: 97984
diff changeset
691 (lglyph-char glyph) (lglyph-char glyph)))
101927
c63836b5986a (describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents: 101781
diff changeset
692 (setq from (1+ from)))))
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
693 (insert " by the rule:\n\t(")
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
694 (let ((first t))
97005
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
695 (mapc (lambda (x)
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
696 (if first (setq first nil)
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
697 (insert " "))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
698 (if (consp x) (insert (format "%S" x))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
699 (if (= x ?\t) (insert (single-key-description x))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
700 (insert ??)
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
701 (insert (describe-char-padded-string x)))))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
702 (nth 2 composition)))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
703 (insert ")\nThe component character(s) are displayed by ")
91180
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
704 (if (display-graphic-p (selected-frame))
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
705 (progn
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
706 (insert "these fonts (glyph codes):")
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
707 (dolist (elt component-chars)
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
708 (if (/= (car elt) ?\t)
97005
8e17e43e57e9 * descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents: 96754
diff changeset
709 (insert "\n "
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
710 (describe-char-padded-string (car elt))
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
711 ?:
91180
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
712 (propertize " " 'display '(space :align-to 5))
96416
959951d0e3b9 (describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents: 95841
diff changeset
713 (or (cdr elt) "-- no font --")))))
91180
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
714 (insert "these terminal codes:")
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
715 (dolist (elt component-chars)
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
716 (insert "\n " (car elt) ":"
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
717 (propertize " " 'display '(space :align-to 4))
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
718 (or (cdr elt) "-- not encodable --"))))
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
719 (insert "\nSee the variable `reference-point-alist' for "
583ca8a88936 (describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents: 91085
diff changeset
720 "the meaning of the rule.\n")))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
721
101304
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
722 (unless eight-bit-p
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
723 (insert (if (not describe-char-unidata-list)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
724 "\nCharacter code properties are not shown: "
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
725 "\nCharacter code properties: "))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
726 (insert-text-button
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
727 "customize what to show"
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
728 'action (lambda (&rest ignore)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
729 (customize-variable
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
730 'describe-char-unidata-list)))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
731 (insert "\n")
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
732 (dolist (elt (if (eq describe-char-unidata-list t)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
733 (nreverse (mapcar 'car char-code-property-alist))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
734 describe-char-unidata-list))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
735 (let ((val (get-char-code-property char elt))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
736 description)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
737 (when val
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
738 (setq description (char-code-property-description elt val))
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
739 (insert (if description
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
740 (format " %s: %s (%s)\n" elt val description)
83173cd662ed (describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents: 101290
diff changeset
741 (format " %s: %s\n" elt val)))))))
45868
97041c98624e (describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents: 45700
diff changeset
742
67542
c6a040f6797b (describe-char): Rework last fix to solve the problem
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 67371
diff changeset
743 (if text-props-desc (insert text-props-desc))
67865
f94acc1b8bc2 (describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents: 67855
diff changeset
744 (setq help-xref-stack-item (list 'help-insert-string (buffer-string)))
86008
054e548612aa (describe-char): Use with-help-window instead of with-output-to-temp-buffer.
Martin Rudalics <rudalics@gmx.at>
parents: 78236
diff changeset
745 (toggle-read-only 1)))))
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
746
94147
587f5f26f25d (describe-char-after): Use `define-obsolete-function-alias'.
Juanma Barranquero <lekktu@gmail.com>
parents: 93058
diff changeset
747 (define-obsolete-function-alias 'describe-char-after 'describe-char "22.1")
51127
d68739c97632 (unicodedata-file): New.
Dave Love <fx@gnu.org>
parents: 49588
diff changeset
748
45700
a54155344566 (toplevel): Provide `descr-text'.
Colin Walters <walters@gnu.org>
parents: 45697
diff changeset
749 (provide 'descr-text)
a54155344566 (toplevel): Provide `descr-text'.
Colin Walters <walters@gnu.org>
parents: 45697
diff changeset
750
58416
28906724d6e3 (syntax-after): Undo last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 58150
diff changeset
751 ;; arch-tag: fc55a498-f3e9-4312-b5bd-98cc02480af1
45022
4359b383982c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
752 ;;; descr-text.el ends here