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