Mercurial > emacs
annotate lisp/descr-text.el @ 105903:28d5dd02302d
* xmenu.c (Fx_popup_menu): Hide any tooltip before opening a menu.
author | Chong Yidong <cyd@stupidchicken.com> |
---|---|
date | Sun, 08 Nov 2009 00:14:30 +0000 |
parents | 788b904aa868 |
children | a3ea15b56766 |
rev | line source |
---|---|
45057 | 1 ;;; descr-text.el --- describe text mode |
45022 | 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 | 4 ;; 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc. |
45022 | 5 |
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 | 8 ;; Keywords: faces, i18n, Unicode, multilingual |
45022 | 9 |
10 ;; This file is part of GNU Emacs. | |
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 | 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 | 16 |
17 ;; GNU Emacs is distributed in the hope that it will be useful, | |
18 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
20 ;; GNU General Public License for more details. | |
21 | |
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 | 24 |
25 ;;; Commentary: | |
26 | |
27 ;;; Describe-Text Mode. | |
28 | |
29 ;;; Code: | |
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)) |
105850
788b904aa868
Require help-mode rather than help-fns (bug#4861).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
105372
diff
changeset
|
32 (require 'help-mode) |
51127 | 33 |
45022 | 34 ;;; Describe-Text Utilities. |
35 | |
36 (defun describe-text-widget (widget) | |
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 | 46 |
47 (defun describe-text-sexp (sexp) | |
48 "Insert a short description of SEXP in the current buffer." | |
49 (let ((pp (condition-case signal | |
50 (pp-to-string sexp) | |
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 | 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 | 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 | 66 "Insert a description of PROPERTIES in the current buffer. |
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 | 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)) |
102872
bd89d8afd5eb
* descr-text.el (describe-property-list, describe-char): Add
Chong Yidong <cyd@stupidchicken.com>
parents:
101927
diff
changeset
|
87 'follow-link t |
67814
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
88 '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
|
89 ((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
|
90 (insert-text-button |
f94acc1b8bc2
(describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents:
67855
diff
changeset
|
91 (format "%S" value) |
f94acc1b8bc2
(describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents:
67855
diff
changeset
|
92 '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
|
93 ((widgetp value) |
45022 | 94 (describe-text-widget value)) |
95 (t | |
58994
720c9b9bf376
(describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents:
58416
diff
changeset
|
96 (describe-text-sexp value)))) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
97 (insert "\n"))) |
45022 | 98 |
99 ;;; Describe-Text Commands. | |
100 | |
101 (defun describe-text-category (category) | |
102 "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
|
103 (interactive "SCategory: ") |
105372
bd2966850aac
Use `called-interactively-p' instead of `interactive-p'.
Juanma Barranquero <lekktu@gmail.com>
parents:
102872
diff
changeset
|
104 (help-setup-xref (list #'describe-text-category category) |
bd2966850aac
Use `called-interactively-p' instead of `interactive-p'.
Juanma Barranquero <lekktu@gmail.com>
parents:
102872
diff
changeset
|
105 (called-interactively-p 'interactive)) |
45022 | 106 (save-excursion |
47601
7d00d911e8b9
(describe-text-category): Use *Help*. Don't kill-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
47379
diff
changeset
|
107 (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
|
108 (set-buffer standard-output) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
109 (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
|
110 (describe-property-list (symbol-plist category)) |
45022 | 111 (goto-char (point-min))))) |
112 | |
113 ;;;###autoload | |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
114 (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
|
115 "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
|
116 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
|
117 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
|
118 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
|
119 otherwise." |
45022 | 120 (interactive "d") |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
121 (if (>= pos (point-max)) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
122 (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
|
123 (if output-buffer |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
124 (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
|
125 (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
|
126 (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
|
127 (let ((buffer (current-buffer)) |
6d1cf277e127
(describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents:
57181
diff
changeset
|
128 (target-buffer "*Help*")) |
6d1cf277e127
(describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents:
57181
diff
changeset
|
129 (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
|
130 (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
|
131 (save-excursion |
57857
6d1cf277e127
(describe-text-properties): Don't err if called in
Kim F. Storm <storm@cua.dk>
parents:
57181
diff
changeset
|
132 (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
|
133 (set-buffer standard-output) |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
134 (setq output-buffer (current-buffer)) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
135 (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
|
136 (with-current-buffer buffer |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
137 (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
|
138 (goto-char (point-min)))))))) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
139 |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
140 (defun describe-text-properties-1 (pos output-buffer) |
45022 | 141 (let* ((properties (text-properties-at pos)) |
142 (overlays (overlays-at pos)) | |
143 (wid-field (get-char-property pos 'field)) | |
144 (wid-button (get-char-property pos 'button)) | |
145 (wid-doc (get-char-property pos 'widget-doc)) | |
146 ;; If button.el is not loaded, we have no buttons in the text. | |
147 (button (and (fboundp 'button-at) (button-at pos))) | |
148 (button-type (and button (button-type button))) | |
149 (button-label (and button (button-label button))) | |
150 (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
|
151 (with-current-buffer output-buffer |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
152 ;; Widgets |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
153 (when (widgetp widget) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
154 (newline) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
155 (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
|
156 (wid-button "This is an active area") |
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
157 (wid-doc "This is documentation text"))) |
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
158 (insert " of a ") |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
159 (describe-text-widget widget) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
160 (insert ".\n\n")) |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
161 ;; Buttons |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
162 (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
|
163 (newline) |
67865
f94acc1b8bc2
(describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents:
67855
diff
changeset
|
164 (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
|
165 "' 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
|
166 ;; Overlays |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
167 (when overlays |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
168 (newline) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
169 (if (eq (length overlays) 1) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
170 (insert "There is an overlay here:\n") |
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
171 (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
|
172 " overlays here:\n")) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
173 (dolist (overlay overlays) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
174 (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
|
175 " 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
|
176 (describe-property-list (overlay-properties overlay))) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
177 (insert "\n")) |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
178 ;; Text properties |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
179 (when properties |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
180 (newline) |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
181 (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
|
182 (describe-property-list properties))))) |
51278
7192dc1bfcf4
(describe-char-unicode-data): New dummy definition.
Richard M. Stallman <rms@gnu.org>
parents:
51127
diff
changeset
|
183 |
96754
79e210b5bd7b
(describe-char-unidata-list): Initialize to the
Kenichi Handa <handa@m17n.org>
parents:
96416
diff
changeset
|
184 (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
|
185 '(name old-name general-category decomposition) |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
186 "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
|
187 :group 'mule |
90104
a01e7a9f1659
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-14
Miles Bader <miles@gnu.org>
parents:
90103
diff
changeset
|
188 :version "23.1" |
93054
ca8b9e092766
(describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91335
diff
changeset
|
189 :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
|
190 (set |
ca8b9e092766
(describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91335
diff
changeset
|
191 (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
|
192 (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
|
193 (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
|
194 (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
|
195 canonical-combining-class) |
ca8b9e092766
(describe-char-unidata-list): Allow specifying just all properties.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91335
diff
changeset
|
196 (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
|
197 (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
|
198 (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
|
199 (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
|
200 (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
|
201 (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
|
202 (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
|
203 (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
|
204 (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
|
205 (const :tag "Unicode simple titlecase mapping" titlecase)))) |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
206 |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
207 (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
|
208 "Location of Unicode data file. |
74356
25c9571827a2
*** empty log message ***
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
209 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
|
210 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
|
211 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
|
212 multilingual development. |
51127 | 213 |
74356
25c9571827a2
*** empty log message ***
Juanma Barranquero <lekktu@gmail.com>
parents:
68651
diff
changeset
|
214 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
|
215 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
|
216 `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
|
217 :group 'mule |
59996
aac0a33f5772
Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents:
59758
diff
changeset
|
218 :version "22.1" |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
219 :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
|
220 file)) |
51278
7192dc1bfcf4
(describe-char-unicode-data): New dummy definition.
Richard M. Stallman <rms@gnu.org>
parents:
51127
diff
changeset
|
221 |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
222 (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
|
223 "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
|
224 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
|
225 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
|
226 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
|
227 (when describe-char-unicodedata-file |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
228 (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
|
229 (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
|
230 (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
|
231 (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
|
232 ;; 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
|
233 (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
|
234 (goto-char (point-min)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
235 (let ((hex (format "%04X" char)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
236 found first last) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
237 (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
|
238 (setq found t) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
239 ;; 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
|
240 ;; 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
|
241 (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
|
242 (>= char (setq first |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
243 (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
|
244 (progn |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
245 (forward-line 1) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
246 (looking-at "^\\([^;]+\\);[^;]+Last>;") |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
247 (> char |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
248 (setq last |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
249 (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
|
250 (if (and (>= char first) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
251 (<= char last)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
252 (setq found t))) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
253 (if found |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
254 (let ((fields (mapcar (lambda (elt) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
255 (if (> (length elt) 0) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
256 elt)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
257 (cdr (split-string |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
258 (buffer-substring |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
259 (line-beginning-position) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
260 (line-end-position)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
261 ";"))))) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
262 ;; 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
|
263 (unless (or (= 13 (length fields)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
264 (= 14 (length fields))) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
265 (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
|
266 ;; 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
|
267 ;; 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
|
268 (list |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
269 (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
|
270 ;; Check for <..., First>, <..., Last> |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
271 (if (string-match "\\`\\(<[^,]+\\)," name) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
272 (concat (match-string 1 name) ">") |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
273 name))) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
274 (list "Category" |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
275 (let ((val (nth 1 fields))) |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
276 (or (char-code-property-description |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
277 'general-category (intern val)) |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
278 val))) |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
279 (list "Combining class" |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
280 (let ((val (nth 1 fields))) |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
281 (or (char-code-property-description |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
282 'canonical-combining-class (intern val)) |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
283 val))) |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
284 (list "Bidi category" |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
285 (let ((val (nth 1 fields))) |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
286 (or (char-code-property-description |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
287 'bidi-class (intern val)) |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
288 val))) |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
289 (list |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
290 "Decomposition" |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
291 (if (nth 4 fields) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
292 (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
|
293 (info (car parts))) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
294 (if (string-match "\\`<\\(.+\\)>\\'" info) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
295 (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
|
296 (setq info nil)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
297 (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
|
298 (setq parts (mapconcat |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
299 (lambda (arg) |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
300 (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
|
301 parts " ")) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
302 (concat info parts)))) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
303 (list "Decimal digit value" |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
304 (nth 5 fields)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
305 (list "Digit value" |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
306 (nth 6 fields)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
307 (list "Numeric value" |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
308 (nth 7 fields)) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
309 (list "Mirrored" |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
310 (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
|
311 "yes")) |
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
312 (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
|
313 (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
|
314 (list "Uppercase" (and (nth 11 fields) |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
315 (string (string-to-number |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
316 (nth 11 fields) 16)))) |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
317 (list "Lowercase" (and (nth 12 fields) |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
318 (string (string-to-number |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
319 (nth 12 fields) 16)))) |
55584
bdbbd721cc67
(describe-char-unicode-data, describe-char-unicodedata-file):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
55543
diff
changeset
|
320 (list "Titlecase" (and (nth 13 fields) |
90087
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
321 (string (string-to-number |
230281e520b3
(describe-char-unidata-list): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90085
diff
changeset
|
322 (nth 13 fields) 16))))))))))) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
323 |
95841
b4e36ff621b3
Add some compiler declarations, for builds without X.
Glenn Morris <rgm@gnu.org>
parents:
95455
diff
changeset
|
324 ;; 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
|
325 (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
|
326 |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
327 ;; 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
|
328 ;; 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
|
329 ;; 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
|
330 ;; FONT-DRIVER is the font-driver name, |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
331 ;; FONT-NAME is the font name, |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
332 ;; 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
|
333 ;; 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
|
334 ;; character. |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
335 (defun describe-char-display (pos char) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
336 (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
|
337 (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
|
338 (if char-font-info |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
339 (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
|
340 (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
|
341 (code (cdr char-font-info))) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
342 (if (integerp code) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
343 (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
|
344 (format "%s:%s (#x%04X%04X)" |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
345 type name (car code) (cdr code)))))) |
97196
15d4d10ad710
(describe-char-display): Call encode-coding-char
Kenichi Handa <handa@m17n.org>
parents:
97005
diff
changeset
|
346 (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
|
347 (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
|
348 (encoded (encode-coding-char char coding charset))) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
349 (if encoded |
97259
067d03b2ec89
* descr-text.el (describe-char-display): Fix last change:
Juanma Barranquero <lekktu@gmail.com>
parents:
97196
diff
changeset
|
350 (encoded-string-description encoded coding))))) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
351 |
51278
7192dc1bfcf4
(describe-char-unicode-data): New dummy definition.
Richard M. Stallman <rms@gnu.org>
parents:
51127
diff
changeset
|
352 |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
353 ;; 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
|
354 ;; 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
|
355 (defsubst describe-char-padded-string (ch) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
356 (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
|
357 |
101290
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
358 ;; 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
|
359 ;; 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
|
360 (defsubst describe-char-categories (category-set) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
361 (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
|
362 (unless (eq mnemonics "") |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
363 (list (mapconcat |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
364 #'(lambda (x) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
365 (let* ((c (category-docstring x)) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
366 (doc (if (string-match "\\`\\(.*?\\)\n\\(.*\\)\\'" c) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
367 (propertize (match-string 1 c) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
368 'help-echo (match-string 2 c)) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
369 c))) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
370 (format "%c:%s" x doc))) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
371 mnemonics ", "))))) |
017ab5339c4c
* descr-text.el (describe-char-categories): New defsubst.
Juanma Barranquero <lekktu@gmail.com>
parents:
100908
diff
changeset
|
372 |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
373 ;;;###autoload |
67855
d6290d5c2df4
(describe-char): Set help-xref-stack-item
Nick Roberts <nickrob@snap.net.nz>
parents:
67815
diff
changeset
|
374 (defun describe-char (pos) |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
375 "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
|
376 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
|
377 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
|
378 character composition information (if relevant), |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
379 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
|
380 (interactive "d") |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
381 (if (>= pos (point-max)) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
382 (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
|
383 (let* ((char (char-after pos)) |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
384 (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
|
385 (charset (if eight-bit-p 'eight-bit |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
386 (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
|
387 (composition (find-composition pos nil nil t)) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
388 (component-chars nil) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
389 (display-table (or (window-display-table) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
390 buffer-display-table |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
391 standard-display-table)) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
392 (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
|
393 (multibyte-p enable-multibyte-characters) |
55305
b1c52f4076c4
(describe-char): Copy the character with text
Kenichi Handa <handa@m17n.org>
parents:
55036
diff
changeset
|
394 (overlays (mapcar #'(lambda (o) (overlay-properties o)) |
b1c52f4076c4
(describe-char): Copy the character with text
Kenichi Handa <handa@m17n.org>
parents:
55036
diff
changeset
|
395 (overlays-at pos))) |
67050
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
396 (char-description (if (not multibyte-p) |
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 (if (< char 128) |
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
399 (single-key-description char) |
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
400 (string-to-multibyte |
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
401 (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
|
402 (text-props-desc |
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
403 (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
|
404 (unwind-protect |
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
405 (progn |
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
406 (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
|
407 (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
|
408 (kill-buffer tmp-buf)))) |
89943
4c90ffeb71c5
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15
Miles Bader <miles@gnu.org>
diff
changeset
|
409 item-list max-width code) |
51127 | 410 |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
411 (if multibyte-p |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
412 (or (setq code (encode-char char charset)) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
413 (setq charset (char-charset char) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
414 code (encode-char char charset))) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
415 (setq code char)) |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
416 (when composition |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
417 ;; 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
|
418 ;; current character itself without any alternate characters), |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
419 ;; 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
|
420 ;; 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
|
421 ;; COMPOSITION. |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
422 (or (catch 'tag |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
423 (let ((from (car composition)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
424 (to (nth 1 composition)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
425 (next (1+ pos)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
426 (components (nth 2 composition)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
427 ch) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
428 (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
|
429 (let ((idx (- pos from)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
430 (nglyphs (lgstring-glyph-len components)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
431 (i 0) j glyph glyph-from) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
432 ;; COMPONENTS is a gstring. Find a grapheme |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
433 ;; cluster containing the current character. |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
434 (while (and (< i nglyphs) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
435 (setq glyph (lgstring-glyph components i)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
436 (< (lglyph-to glyph) idx)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
437 (setq i (1+ i))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
438 (if (or (not glyph) (= i nglyphs)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
439 ;; The composition is broken. |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
440 (throw 'tag nil)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
441 (setq glyph-from (lglyph-from glyph) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
442 to (+ from (lglyph-to glyph) 1) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
443 from (+ from glyph-from) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
444 j i) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
445 (while (and (< j nglyphs) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
446 (setq glyph (lgstring-glyph components j)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
447 (= (lglyph-from glyph) glyph-from)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
448 (setq j (1+ j))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
449 (if (and (= i (1- j)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
450 (setq glyph (lgstring-glyph components i)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
451 (= char (lglyph-char glyph))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
452 ;; The composition is trivial. |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
453 (throw 'tag nil)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
454 (nconc composition (list i (1- j)))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
455 (dotimes (i (length components)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
456 (if (integerp (setq ch (aref components i))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
457 (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
|
458 component-chars))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
459 (setq component-chars (nreverse component-chars))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
460 (if (< from pos) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
461 (if (< (1+ pos) to) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
462 (setcar composition |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
463 (concat |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
464 " with the surrounding characters \"" |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
465 (mapconcat 'describe-char-padded-string |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
466 (buffer-substring from pos) "") |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
467 "\" and \"" |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
468 (mapconcat 'describe-char-padded-string |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
469 (buffer-substring (1+ pos) to) "") |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
470 "\"")) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
471 (setcar composition |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
472 (concat |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
473 " with the preceding character(s) \"" |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
474 (mapconcat 'describe-char-padded-string |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
475 (buffer-substring from pos) "") |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
476 "\""))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
477 (if (< (1+ pos) to) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
478 (setcar composition |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
479 (concat |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
480 " with the following character(s) \"" |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
481 (mapconcat 'describe-char-padded-string |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
482 (buffer-substring (1+ pos) to) "") |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
483 "\"")) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
484 (setcar composition nil))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
485 (setcar (cdr composition) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
486 (format "composed to form \"%s\" (see below)" |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
487 (buffer-substring from to))))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
488 (setq composition nil))) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
489 |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
490 (setq item-list |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
491 `(("character" |
90261
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
492 ,(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
|
493 (apply 'propertize char-description |
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
494 (text-properties-at pos)) |
90261
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
495 char char char)) |
89943
4c90ffeb71c5
Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15
Miles Bader <miles@gnu.org>
diff
changeset
|
496 ("preferred charset" |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
497 ,`(insert-text-button |
67814
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
498 ,(symbol-name charset) |
cc79e7966f97
2005-12-27 Nick Roberts <nickrob@snap.net.nz>
Nick Roberts <nickrob@snap.net.nz>
parents:
67752
diff
changeset
|
499 '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
|
500 ,(format "(%s)" (charset-description charset))) |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
501 ("code point" |
90215
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
502 ,(let ((str (if (integerp code) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
503 (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
|
504 (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
|
505 (if (<= (charset-dimension charset) 2) |
90261
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
506 `(insert-text-button |
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
507 ,str |
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
508 'action (lambda (&rest ignore) |
90215
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
509 (list-charset-chars ',charset) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
510 (with-selected-window |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
511 (get-buffer-window "*Character List*" 0) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
512 (goto-char (point-min)) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
513 (forward-line 2) ;Skip the header. |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
514 (let ((case-fold-search nil)) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
515 (if (search-forward ,(char-to-string char) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
516 nil t) |
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
517 (goto-char (match-beginning 0)))))) |
102872
bd89d8afd5eb
* descr-text.el (describe-property-list, describe-char): Add
Chong Yidong <cyd@stupidchicken.com>
parents:
101927
diff
changeset
|
518 'follow-link t |
90261
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
519 'help-echo |
7beb78bc1f8e
Revision: miles@gnu.org--gnu-2005/emacs--unicode--0--patch-97
Miles Bader <miles@gnu.org>
diff
changeset
|
520 "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
|
521 str))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
522 ("syntax" |
58416
28906724d6e3
(syntax-after): Undo last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58150
diff
changeset
|
523 ,(let ((syntax (syntax-after pos))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
524 (with-temp-buffer |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
525 (internal-describe-syntax-value syntax) |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
526 (buffer-string)))) |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
527 ("category" |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
528 ,@(if (not eight-bit-p) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
529 (let ((category-set (char-category-set char))) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
530 (if category-set |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
531 (describe-char-categories category-set) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
532 '("-- none --"))))) |
55543
7b6cb8aae6f3
Require quail at comile time.
Kenichi Handa <handa@m17n.org>
parents:
55491
diff
changeset
|
533 ("to input" |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
534 ,@(if (not eight-bit-p) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
535 (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
|
536 'quail-input-method) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
537 (quail-find-key char)))) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
538 (if (consp key-list) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
539 (list "type" |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
540 (mapconcat #'(lambda (x) (concat "\"" x "\"")) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
541 key-list " or ") |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
542 "with" |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
543 `(insert-text-button |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
544 ,current-input-method |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
545 'type 'help-input-method |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
546 'help-args '(,current-input-method))))))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
547 ("buffer code" |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
548 ,(if multibyte-p |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
549 (encoded-string-description |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
550 (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
|
551 (format "#x%02X" char))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
552 ("file code" |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
553 ,@(if multibyte-p |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
554 (let* ((coding buffer-file-coding-system) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
555 (encoded (encode-coding-char char coding charset))) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
556 (if encoded |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
557 (list (encoded-string-description encoded coding) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
558 (format "(encoded by coding system %S)" coding)) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
559 (list "not encodable by coding system" |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
560 (symbol-name coding)))) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
561 (list (format "#x%02X" char)))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
562 ("display" |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
563 ,(cond |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
564 (disp-vector |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
565 (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
|
566 (dotimes (i (length disp-vector)) |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
567 (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
|
568 (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
|
569 (describe-char-display |
8e17e43e57e9
* descr-text.el (describe-char): Don't overwrite local variable char
Juanma Barranquero <lekktu@gmail.com>
parents:
96754
diff
changeset
|
570 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
|
571 (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
|
572 (mapconcat |
720c9b9bf376
(describe-property-list): Don't treat syntax-table
Juri Linkov <juri@jurta.org>
parents:
58416
diff
changeset
|
573 #'(lambda (x) |
75872
a527b46e9ab2
(describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents:
75347
diff
changeset
|
574 (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
|
575 disp-vector " "))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
576 (composition |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
577 (cadr composition)) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
578 (t |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
579 (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
|
580 (if (display-graphic-p (selected-frame)) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
581 (if display |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
582 (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
|
583 "no font available") |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
584 (if display |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
585 (format "terminal code %s" display) |
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
586 "not encodable for terminal")))))) |
64495
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
587 ,@(let ((face |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
588 (if (not (or disp-vector composition)) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
589 (cond |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
590 ((and show-trailing-whitespace |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
591 (save-excursion (goto-char pos) |
95455
a11e3f3131cc
(describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents:
94678
diff
changeset
|
592 (looking-at-p "[ \t]+$"))) |
64495
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
593 'trailing-whitespace) |
90215
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
594 ((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
|
595 'nobreak-space) |
90215
7217d5a385f8
(describe-char): Sync with the main trunk.
Kenichi Handa <handa@m17n.org>
parents:
90203
diff
changeset
|
596 ((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
|
597 'escape-glyph) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
598 ((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
|
599 'escape-glyph))))) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
600 (if face (list (list "hardcoded face" |
67865
f94acc1b8bc2
(describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents:
67855
diff
changeset
|
601 `(insert-text-button |
f94acc1b8bc2
(describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents:
67855
diff
changeset
|
602 ,(symbol-name face) |
f94acc1b8bc2
(describe-text-sexp): Use square brackets for
Juri Linkov <juri@jurta.org>
parents:
67855
diff
changeset
|
603 'type 'help-face 'help-args '(,face)))))) |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
604 ,@(if (not eight-bit-p) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
605 (let ((unicodedata (describe-char-unicode-data char))) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
606 (if unicodedata |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
607 (cons (list "Unicode data" " ") unicodedata)))))) |
93058
273ed23a0a68
(describe-char): When specifying all properties,
Juanma Barranquero <lekktu@gmail.com>
parents:
93054
diff
changeset
|
608 (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
|
609 (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
|
610 item-list))) |
105372
bd2966850aac
Use `called-interactively-p' instead of `interactive-p'.
Juanma Barranquero <lekktu@gmail.com>
parents:
102872
diff
changeset
|
611 (help-setup-xref nil (called-interactively-p 'interactive)) |
86008
054e548612aa
(describe-char): Use with-help-window instead of with-output-to-temp-buffer.
Martin Rudalics <rudalics@gmx.at>
parents:
78236
diff
changeset
|
612 (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
|
613 (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
|
614 (set-buffer-multibyte multibyte-p) |
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
615 (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
|
616 (dolist (elt item-list) |
51127 | 617 (when (cadr elt) |
618 (insert (format formatter (car elt))) | |
619 (dolist (clm (cdr elt)) | |
67752
dd459879f1e7
Add FSF as maintainer.
Nick Roberts <nickrob@snap.net.nz>
parents:
67559
diff
changeset
|
620 (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
|
621 (progn (insert " ") (eval clm)) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
622 (when (>= (+ (current-column) |
95455
a11e3f3131cc
(describe-text-sexp): Use `string-match-p'. Simplify.
Juanma Barranquero <lekktu@gmail.com>
parents:
94678
diff
changeset
|
623 (or (string-match-p "\n" clm) |
64495
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
624 (string-width clm)) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
625 1) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
626 (window-width)) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
627 (insert "\n") |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
628 (indent-to (1+ max-width))) |
524cffc1c27d
(describe-char): Create link buttons for `charset'
Juri Linkov <juri@jurta.org>
parents:
64091
diff
changeset
|
629 (insert " " clm))) |
51127 | 630 (insert "\n")))) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
631 |
67371
0df745d01551
(describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents:
67050
diff
changeset
|
632 (when overlays |
0df745d01551
(describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents:
67050
diff
changeset
|
633 (save-excursion |
0df745d01551
(describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents:
67050
diff
changeset
|
634 (goto-char (point-min)) |
0df745d01551
(describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents:
67050
diff
changeset
|
635 (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
|
636 (let ((end (+ (point) (length char-description)))) |
67050
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
637 (mapc #'(lambda (props) |
67371
0df745d01551
(describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents:
67050
diff
changeset
|
638 (let ((o (make-overlay (point) end))) |
67050
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
639 (while props |
c365e04ea266
(describe-char): When copying overlays put them
Andreas Schwab <schwab@suse.de>
parents:
67035
diff
changeset
|
640 (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
|
641 (setq props (cddr props))))) |
67371
0df745d01551
(describe-char): Use *Help-2* buffer if the
Kenichi Handa <handa@m17n.org>
parents:
67050
diff
changeset
|
642 overlays)))) |
55491
79abf8a72f5a
(describe-char): Fix previous change. Don't make
Kenichi Handa <handa@m17n.org>
parents:
55305
diff
changeset
|
643 |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
644 (when disp-vector |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
645 (insert |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
646 "\nThe display table entry is displayed by ") |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
647 (if (display-graphic-p (selected-frame)) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
648 (progn |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
649 (insert "these fonts (glyph codes):\n") |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
650 (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
|
651 (insert (glyph-char (car (aref disp-vector i))) ?: |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
652 (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
|
653 (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
|
654 "\n") |
75872
a527b46e9ab2
(describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents:
75347
diff
changeset
|
655 (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
|
656 (when face |
a527b46e9ab2
(describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents:
75347
diff
changeset
|
657 (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
|
658 "face: ") |
a527b46e9ab2
(describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents:
75347
diff
changeset
|
659 (insert (concat "`" (symbol-name face) "'")) |
a527b46e9ab2
(describe-char): Use glyph-char and glyph-face.
Kim F. Storm <storm@cua.dk>
parents:
75347
diff
changeset
|
660 (insert "\n"))))) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
661 (insert "these terminal codes:\n") |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
662 (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
|
663 (insert (car (aref disp-vector i)) |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
664 (propertize " " 'display '(space :align-to 5)) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
665 (or (cdr (aref disp-vector i)) "-- not encodable --") |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
666 "\n")))) |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
667 |
45868
97041c98624e
(describe-char): Moved from mule-diag.el, renamed
Richard M. Stallman <rms@gnu.org>
parents:
45700
diff
changeset
|
668 (when composition |
52655
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
669 (insert "\nComposed") |
8d4e6d1d7201
(describe-char-display): New function.
Kenichi Handa <handa@m17n.org>
parents:
52401
diff
changeset
|
670 (if (car composition) |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
671 (insert (car composition))) |
91180
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
672 (if (and (vectorp (nth 2 composition)) |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
673 (vectorp (aref (nth 2 composition) 0))) |
97984
672009e514b4
(describe-char): Fix handling of automatic composition.
Kenichi Handa <handa@m17n.org>
parents:
97259
diff
changeset
|
674 (let* ((gstring (nth 2 composition)) |
672009e514b4
(describe-char): Fix handling of automatic composition.
Kenichi Handa <handa@m17n.org>
parents:
97259
diff
changeset
|
675 (font (lgstring-font gstring)) |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
676 (from (nth 3 composition)) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
677 (to (nth 4 composition)) |
97984
672009e514b4
(describe-char): Fix handling of automatic composition.
Kenichi Handa <handa@m17n.org>
parents:
97259
diff
changeset
|
678 glyph) |
101781
7d00428842ae
(describe-char): Check font-object by fontp.
Kenichi Handa <handa@m17n.org>
parents:
101304
diff
changeset
|
679 (if (fontp font) |
99151
524569e0f990
(describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents:
97984
diff
changeset
|
680 (progn |
524569e0f990
(describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents:
97984
diff
changeset
|
681 (insert " using this font:\n " |
524569e0f990
(describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents:
97984
diff
changeset
|
682 (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
|
683 ?: |
524569e0f990
(describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents:
97984
diff
changeset
|
684 (aref (query-font font) 0) |
524569e0f990
(describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents:
97984
diff
changeset
|
685 "\nby these glyphs:\n") |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
686 (while (and (<= from to) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
687 (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
|
688 (insert (format " %S\n" glyph)) |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
689 (setq from (1+ from)))) |
99151
524569e0f990
(describe-char): Fix terminal case (where font is nil).
Kenichi Handa <handa@m17n.org>
parents:
97984
diff
changeset
|
690 (insert " by these characters:\n") |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
691 (while (and (<= from to) |
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
692 (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
|
693 (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
|
694 (lglyph-char glyph) (lglyph-char glyph))) |
101927
c63836b5986a
(describe-char-display): On terminal, if terminal
Kenichi Handa <handa@m17n.org>
parents:
101781
diff
changeset
|
695 (setq from (1+ from))))) |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
696 (insert " by the rule:\n\t(") |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
697 (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
|
698 (mapc (lambda (x) |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
699 (if first (setq first nil) |
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 (if (consp x) (insert (format "%S" x)) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
702 (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
|
703 (insert ??) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
704 (insert (describe-char-padded-string x))))) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
705 (nth 2 composition))) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
706 (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
|
707 (if (display-graphic-p (selected-frame)) |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
708 (progn |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
709 (insert "these fonts (glyph codes):") |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
710 (dolist (elt component-chars) |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
711 (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
|
712 (insert "\n " |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
713 (describe-char-padded-string (car elt)) |
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
714 ?: |
91180
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
715 (propertize " " 'display '(space :align-to 5)) |
96416
959951d0e3b9
(describe-char-display): Always return a string.
Kenichi Handa <handa@m17n.org>
parents:
95841
diff
changeset
|
716 (or (cdr elt) "-- no font --"))))) |
91180
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
717 (insert "these terminal codes:") |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
718 (dolist (elt component-chars) |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
719 (insert "\n " (car elt) ":" |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
720 (propertize " " 'display '(space :align-to 4)) |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
721 (or (cdr elt) "-- not encodable --")))) |
583ca8a88936
(describe-char): Handle a composition of the new
Kenichi Handa <handa@m17n.org>
parents:
91085
diff
changeset
|
722 (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
|
723 "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
|
724 |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
725 (unless eight-bit-p |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
726 (insert (if (not describe-char-unidata-list) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
727 "\nCharacter code properties are not shown: " |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
728 "\nCharacter code properties: ")) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
729 (insert-text-button |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
730 "customize what to show" |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
731 'action (lambda (&rest ignore) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
732 (customize-variable |
102872
bd89d8afd5eb
* descr-text.el (describe-property-list, describe-char): Add
Chong Yidong <cyd@stupidchicken.com>
parents:
101927
diff
changeset
|
733 'describe-char-unidata-list)) |
bd89d8afd5eb
* descr-text.el (describe-property-list, describe-char): Add
Chong Yidong <cyd@stupidchicken.com>
parents:
101927
diff
changeset
|
734 'follow-link t) |
101304
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
735 (insert "\n") |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
736 (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
|
737 (nreverse (mapcar 'car char-code-property-alist)) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
738 describe-char-unidata-list)) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
739 (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
|
740 description) |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
741 (when val |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
742 (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
|
743 (insert (if description |
83173cd662ed
(describe-char): Improve description of eight-bit
Kenichi Handa <handa@m17n.org>
parents:
101290
diff
changeset
|
744 (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
|
745 (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
|
746 |
67542
c6a040f6797b
(describe-char): Rework last fix to solve the problem
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
67371
diff
changeset
|
747 (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
|
748 (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
|
749 (toggle-read-only 1))))) |
45022 | 750 |
94147
587f5f26f25d
(describe-char-after): Use `define-obsolete-function-alias'.
Juanma Barranquero <lekktu@gmail.com>
parents:
93058
diff
changeset
|
751 (define-obsolete-function-alias 'describe-char-after 'describe-char "22.1") |
51127 | 752 |
45700
a54155344566
(toplevel): Provide `descr-text'.
Colin Walters <walters@gnu.org>
parents:
45697
diff
changeset
|
753 (provide 'descr-text) |
a54155344566
(toplevel): Provide `descr-text'.
Colin Walters <walters@gnu.org>
parents:
45697
diff
changeset
|
754 |
58416
28906724d6e3
(syntax-after): Undo last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
58150
diff
changeset
|
755 ;; arch-tag: fc55a498-f3e9-4312-b5bd-98cc02480af1 |
45022 | 756 ;;; descr-text.el ends here |