annotate lisp/mule/mule-diag.el @ 207:e45d5e7c476e r20-4b2

Import from CVS: tag r20-4b2
author cvs
date Mon, 13 Aug 2007 10:03:52 +0200
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
207
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
1 ;;; mule-diag.el --- Show diagnosis of multilingual environment (MULE)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
2
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
3 ;; Copyright (C) 1995 Electrotechnical Laboratory, JAPAN.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
4 ;; Licensed to the Free Software Foundation.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
5 ;; Copyright (C) 1997 MORIOKA Tomohiko
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
6
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
7 ;; Keywords: multilingual, charset, coding system, fontset, diagnosis
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
8
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
9 ;; This file is part of XEmacs.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
10
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
11 ;; XEmacs is free software; you can redistribute it and/or modify it
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
12 ;; under the terms of the GNU General Public License as published by
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
14 ;; any later version.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
15
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
16 ;; XEmacs is distributed in the hope that it will be useful, but
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
17 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
19 ;; General Public License for more details.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
20
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
22 ;; along with XEmacs; see the file COPYING. If not, write to the Free
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
23 ;; Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
24 ;; 02111-1307, USA.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
25
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
26 ;;; General utility function
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
27
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
28 ;; Print all arguments with single space separator in one line.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
29 (defun print-list (&rest args)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
30 (while (cdr args)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
31 (when (car args)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
32 (princ (car args))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
33 (princ " "))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
34 (setq args (cdr args)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
35 (princ (car args))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
36 (princ "\n"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
37
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
38 ;; Re-order the elements of charset-list.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
39 (defun sort-charset-list ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
40 (setq charset-list
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
41 (sort charset-list
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
42 (function (lambda (x y) (< (charset-id x) (charset-id y)))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
43
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
44 ;;; CHARSET
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
45
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
46 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
47 (defun list-character-sets (&optional arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
48 "Display a list of all character sets.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
49
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
50 The ID column contains a charset identification number for internal use.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
51 The B column contains a number of bytes occupied in a buffer.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
52 The W column contains a number of columns occupied in a screen.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
53
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
54 With prefix arg, the output format gets more cryptic
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
55 but contains full information about each character sets."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
56 (interactive "P")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
57 (sort-charset-list)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
58 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
59 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
60 (set-buffer standard-output)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
61 (let ((l charset-list)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
62 charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
63 (if (null arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
64 (progn
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
65 (insert "ID Name B W Description\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
66 (insert "-- ---- - - -----------\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
67 (while l
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
68 (setq charset (car l) l (cdr l))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
69 (insert (format "%03d %s" (charset-id charset) charset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
70 (indent-to 28)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
71 (insert (format "%d %d %s\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
72 (charset-bytes charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
73 (charset-width charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
74 (charset-description charset)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
75 (insert "\
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
76 #########################
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
77 ## LIST OF CHARSETS
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
78 ## Each line corresponds to one charset.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
79 ## The following attributes are listed in this order
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
80 ## separated by a colon `:' in one line.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
81 ## CHARSET-ID,
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
82 ## CHARSET-SYMBOL-NAME,
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
83 ## DIMENSION (1 or 2)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
84 ## CHARS (94 or 96)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
85 ## BYTES (of multibyte form: 1, 2, 3, or 4),
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
86 ## WIDTH (occupied column numbers: 1 or 2),
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
87 ## DIRECTION (0:left-to-right, 1:right-to-left),
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
88 ## ISO-FINAL-CHAR (character code of ISO-2022's final character)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
89 ## ISO-GRAPHIC-PLANE (ISO-2022's graphic plane, 0:GL, 1:GR)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
90 ## DESCRIPTION (describing string of the charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
91 ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
92 (while l
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
93 (setq charset (car l) l (cdr l))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
94 (princ (format "%03d:%s:%d:%d:%d:%d:%d:%d:%d:%s\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
95 (charset-id charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
96 charset
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
97 (charset-dimension charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
98 (charset-chars charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
99 (charset-bytes charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
100 (charset-width charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
101 (charset-direction charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
102 (charset-iso-final-char charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
103 (charset-iso-graphic-plane charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
104 (charset-description charset))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
105 (help-mode)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
106 (setq truncate-lines t))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
107
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
108 ;;; CODING-SYSTEM
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
109
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
110 (defun describe-designation (cs register)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
111 (let ((charset
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
112 (coding-system-property
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
113 cs (intern (format "charset-g%d" register))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
114 (force
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
115 (coding-system-property
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
116 cs (intern (format "force-g%d-on-output" register)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
117 (princ
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
118 (format
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
119 " G%d: %s%s\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
120 register
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
121 (cond ((null charset) "never used")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
122 ((eq t charset) "none")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
123 (t (charset-name charset)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
124 (if force " (explicit designation required)" "")))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
125
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
126 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
127 (defun describe-coding-system (coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
128 "Display information of CODING-SYSTEM."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
129 (interactive "zDescribe coding system (default, current choices): ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
130 (if (or (null coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
131 (string= (symbol-name coding-system) ""))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
132 (describe-current-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
133 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
134 (print-coding-system-briefly coding-system 'doc-string)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
135 (let ((type (coding-system-type coding-system)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
136 (princ (format "Type: %s" type))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
137 (when (eq type 'iso2022)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
138 (princ " (variant of ISO-2022)\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
139 (princ "Initial designations:\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
140 ;;(print-designation flags)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
141 (describe-designation coding-system 0)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
142 (describe-designation coding-system 1)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
143 (describe-designation coding-system 2)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
144 (describe-designation coding-system 3)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
145 (princ "Other Form: \n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
146 (princ (if (coding-system-short coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
147 "short-form"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
148 "long-form"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
149 (if (coding-system-no-ascii-eol coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
150 (princ ", ASCII@EOL"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
151 (if (coding-system-no-ascii-cntl coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
152 (princ ", ASCII@CNTL"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
153 (princ (if (coding-system-seven coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
154 ", 7-bit"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
155 ", 8-bit"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
156 (if (coding-system-lock-shift coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
157 (princ ", use-locking-shift")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
158 (princ ", use-single-shift"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
159 ;;(if (aref flags 10) (princ ", use-roman"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
160 ;;(if (aref flags 10) (princ ", use-old-jis"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
161 (if (coding-system-no-iso6429 coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
162 (princ ", no-ISO6429"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
163 )
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
164 (princ "\nEOL type:")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
165 (let ((eol-type (coding-system-eol-type coding-system)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
166 (cond ((null eol-type)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
167 (princ "\n Automatic selection from\n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
168 (princ (format "%s-unix, %s-dos or %s-mac.\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
169 coding-system coding-system coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
170 )
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
171 ((symbolp eol-type)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
172 (princ " ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
173 (princ eol-type))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
174 (t (princ "invalid\n")))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
175 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
176 (set-buffer standard-output)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
177 (help-mode)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
178
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
179 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
180 (defun describe-current-coding-system-briefly ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
181 "Display coding systems currently used in a brief format in echo area.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
182
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
183 The format is \"F[..],K[..],T[..],P>[..],P<[..], default F[..],P<[..],P<[..]\",
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
184 where mnemonics of the following coding systems come in this order
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
185 at the place of `..':
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
186 buffer-file-coding-system (of the current buffer)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
187 eol-type of buffer-file-coding-system (of the current buffer)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
188 (keyboard-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
189 eol-type of (keyboard-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
190 (terminal-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
191 eol-type of (terminal-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
192 process-coding-system for read (of the current buffer, if any)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
193 eol-type of process-coding-system for read (of the current buffer, if any)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
194 process-coding-system for write (of the current buffer, if any)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
195 eol-type of process-coding-system for write (of the current buffer, if any)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
196 default-buffer-file-coding-system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
197 eol-type of default-buffer-file-coding-system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
198 default-process-coding-system for read
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
199 eol-type of default-process-coding-system for read
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
200 default-process-coding-system for write
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
201 eol-type of default-process-coding-system"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
202 (interactive)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
203 (let* ((proc (get-buffer-process (current-buffer)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
204 (process-coding-systems (if proc (process-coding-system proc))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
205 (message
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
206 "F[%c%c],K[%c%c],T[%c%c],P>[%c%c],P<[%c%c], default F[%c%c],P>[%c%c],P<[%c%c]"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
207 (coding-system-mnemonic buffer-file-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
208 (coding-system-eol-type-mnemonic buffer-file-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
209 (coding-system-mnemonic (keyboard-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
210 (coding-system-eol-type-mnemonic (keyboard-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
211 (coding-system-mnemonic (terminal-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
212 (coding-system-eol-type-mnemonic (terminal-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
213 (coding-system-mnemonic (car process-coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
214 (coding-system-eol-type-mnemonic (car process-coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
215 (coding-system-mnemonic (cdr process-coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
216 (coding-system-eol-type-mnemonic (cdr process-coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
217 (coding-system-mnemonic default-buffer-file-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
218 (coding-system-eol-type-mnemonic default-buffer-file-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
219 (coding-system-mnemonic (car default-process-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
220 (coding-system-eol-type-mnemonic (car default-process-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
221 (coding-system-mnemonic (cdr default-process-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
222 (coding-system-eol-type-mnemonic (cdr default-process-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
223 )))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
224
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
225 ;; Print symbol name and mnemonic letter of CODING-SYSTEM by `princ'.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
226 (defun print-coding-system-briefly (coding-system &optional doc-string)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
227 (if (not coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
228 (princ "nil\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
229 ;; In XEmacs, coding-system has own type.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
230 (if (coding-system-p coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
231 (setq coding-system (coding-system-name coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
232 )
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
233 ;; In XEmacs, coding-system-mnemonic returns string.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
234 (princ (format "%s -- %s"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
235 (coding-system-mnemonic coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
236 coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
237 ;; Current XEmacs does not have `coding-system-parent'.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
238 ;; (let ((parent (coding-system-parent coding-system)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
239 ;; (if parent
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
240 ;; (princ (format " (alias of %s)" parent))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
241 (let ((aliases (get coding-system 'alias-coding-systems)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
242 (if aliases
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
243 (princ (format " %S" (cons 'alias: aliases)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
244 (princ "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
245 (if (and doc-string
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
246 (setq doc-string (coding-system-doc-string coding-system)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
247 (princ (format " %s\n" doc-string)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
248
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
249 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
250 (defun describe-current-coding-system ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
251 "Display coding systems currently used in a detailed format."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
252 (interactive)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
253 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
254 (let* ((proc (get-buffer-process (current-buffer)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
255 (process-coding-systems (if proc (process-coding-system proc))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
256 (princ "Coding system for saving this buffer:\n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
257 ;; local-variable-p of XEmacs requires 2 arguments.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
258 (if (local-variable-p 'buffer-file-coding-system (current-buffer))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
259 (print-coding-system-briefly buffer-file-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
260 (princ "Not set locally, use the default.\n"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
261 (princ "Default coding system (for new files):\n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
262 (print-coding-system-briefly default-buffer-file-coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
263 (princ "Coding system for keyboard input:\n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
264 (print-coding-system-briefly (keyboard-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
265 (princ "Coding system for terminal output:\n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
266 (print-coding-system-briefly (terminal-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
267 (when (get-buffer-process (current-buffer))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
268 (princ "Coding systems for process I/O:\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
269 (princ " encoding input to the process: ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
270 (print-coding-system-briefly (cdr process-coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
271 (princ " decoding output from the process: ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
272 (print-coding-system-briefly (car process-coding-systems)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
273 ;;(princ "Defaults for subprocess I/O:\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
274 ;;(princ " decoding: ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
275 ;;(print-coding-system-briefly (car default-process-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
276 ;;(princ " encoding: ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
277 ;;(print-coding-system-briefly (cdr default-process-coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
278 )
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
279 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
280 (set-buffer standard-output)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
281
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
282 (princ
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
283 "\nPriority order for recognizing coding systems when reading files:\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
284 (let ((l (coding-category-list)) ; It is function in XEmacs.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
285 (i 1)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
286 (coding-list nil)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
287 coding aliases)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
288 (while l
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
289 (setq coding (coding-category-system (car l))) ; for XEmacs
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
290 (when (not (memq coding coding-list))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
291 (setq coding-list (cons coding coding-list))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
292 (princ (format " %d. %s" i coding))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
293 (when (setq aliases (get coding 'alias-coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
294 (princ " ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
295 (princ (cons 'alias: aliases)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
296 (terpri)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
297 (setq i (1+ i)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
298 (setq l (cdr l))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
299 (princ "\n Other coding systems cannot be distinguished automatically
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
300 from these, and therefore cannot be recognized automatically
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
301 with the present coding system priorities.\n\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
302
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
303 (let ((categories '(iso-7)) ; for XEmacs
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
304 ;; '(coding-category-iso-7 coding-category-iso-7-else))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
305 coding-system codings)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
306 (while categories
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
307 ;; for XEmacs
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
308 (setq coding-system (coding-category-system (car categories)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
309 (mapcar
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
310 (function
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
311 (lambda (x)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
312 (if (and (not (eq x coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
313 (get x 'no-initial-designation)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
314 (let ((flags (coding-system-flags x)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
315 (not (or (aref flags 10) (aref flags 11)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
316 (setq codings (cons x codings)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
317 (get (car categories) 'coding-systems))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
318 (if codings
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
319 (let ((max-col (frame-width))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
320 pos)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
321 (princ (format " The followings are decoded correctly but recognized as %s:\n " coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
322 (while codings
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
323 (setq pos (point))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
324 (insert (format " %s" (car codings)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
325 (when (> (current-column) max-col)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
326 (goto-char pos)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
327 (insert "\n ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
328 (goto-char (point-max)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
329 (setq codings (cdr codings)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
330 (insert "\n\n")))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
331 (setq categories (cdr categories))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
332
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
333 (princ "Particular coding systems specified for certain file names:\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
334 (terpri)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
335 (princ " OPERATION\tTARGET PATTERN\t\tCODING SYSTEM(s)\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
336 (princ " ---------\t--------------\t\t----------------\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
337 (let ((func (lambda (operation alist)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
338 (princ " ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
339 (princ operation)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
340 (if (not alist)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
341 (princ "\tnothing specified\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
342 (while alist
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
343 (indent-to 16)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
344 (prin1 (car (car alist)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
345 (indent-to 40)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
346 (princ (cdr (car alist)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
347 (princ "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
348 (setq alist (cdr alist)))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
349 (funcall func "File I/O" file-coding-system-alist)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
350 (funcall func "Process I/O" process-coding-system-alist)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
351 (funcall func "Network I/O" network-coding-system-alist))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
352 (help-mode))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
353
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
354 ;; Print detailed information on CODING-SYSTEM.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
355 (defun print-coding-system (coding-system &optional aliases)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
356 (let ((type (coding-system-type coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
357 (eol-type (coding-system-eol-type coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
358 (flags (coding-system-flags coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
359 (base (coding-system-base coding-system)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
360 (if (not (eq base coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
361 (princ (format "%s (alias of %s)\n" coding-system base))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
362 (princ coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
363 (while aliases
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
364 (princ ",")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
365 (princ (car aliases))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
366 (setq aliases (cdr aliases)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
367 (princ (format ":%s:%c:%d:"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
368 type
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
369 (coding-system-mnemonic coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
370 (if (integerp eol-type) eol-type 3)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
371 (cond ((eq type 2) ; ISO-2022
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
372 (let ((idx 0)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
373 charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
374 (while (< idx 4)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
375 (setq charset (aref flags idx))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
376 (cond ((null charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
377 (princ -1))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
378 ((eq charset t)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
379 (princ -2))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
380 ((charsetp charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
381 (princ charset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
382 ((listp charset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
383 (princ "(")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
384 (princ (car charset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
385 (setq charset (cdr charset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
386 (while charset
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
387 (princ ",")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
388 (princ (car charset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
389 (setq charset (cdr charset)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
390 (princ ")")))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
391 (princ ",")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
392 (setq idx (1+ idx)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
393 (while (< idx 12)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
394 (princ (if (aref flags idx) 1 0))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
395 (princ ",")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
396 (setq idx (1+ idx)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
397 (princ (if (aref flags idx) 1 0))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
398 ((eq type 4) ; CCL
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
399 (let (i len)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
400 (setq i 0 len (length (car flags)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
401 (while (< i len)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
402 (princ (format " %x" (aref (car flags) i)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
403 (setq i (1+ i)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
404 (princ ",")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
405 (setq i 0 len (length (cdr flags)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
406 (while (< i len)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
407 (princ (format " %x" (aref (cdr flags) i)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
408 (setq i (1+ i)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
409 (t (princ 0)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
410 (princ ":")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
411 (princ (coding-system-doc-string coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
412 (princ "\n"))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
413
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
414 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
415 (defun list-coding-systems (&optional arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
416 "Display a list of all coding systems.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
417 It prints mnemonic letter, name, and description of each coding systems.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
418
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
419 With prefix arg, the output format gets more cryptic,
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
420 but contains full information about each coding systems."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
421 (interactive "P")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
422 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
423 (if (null arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
424 (princ "\
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
425 ###############################################
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
426 # List of coding systems in the following format:
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
427 # MNEMONIC-LETTER -- CODING-SYSTEM-NAME
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
428 # DOC-STRING
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
429 ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
430 (princ "\
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
431 #########################
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
432 ## LIST OF CODING SYSTEMS
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
433 ## Each line corresponds to one coding system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
434 ## Format of a line is:
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
435 ## NAME[,ALIAS...]:TYPE:MNEMONIC:EOL:FLAGS:POST-READ-CONVERSION
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
436 ## :PRE-WRITE-CONVERSION:DOC-STRING,
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
437 ## where
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
438 ## NAME = coding system name
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
439 ## ALIAS = alias of the coding system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
440 ## TYPE = nil (no conversion), t (undecided or automatic detection),
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
441 ## 0 (EMACS-MULE), 1 (SJIS), 2 (ISO2022), 3 (BIG5), or 4 (CCL)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
442 ## EOL = 0 (LF), 1 (CRLF), 2 (CR), or 3 (Automatic detection)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
443 ## FLAGS =
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
444 ## if TYPE = 2 then
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
445 ## comma (`,') separated data of the followings:
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
446 ## G0, G1, G2, G3, SHORT-FORM, ASCII-EOL, ASCII-CNTL, SEVEN,
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
447 ## LOCKING-SHIFT, SINGLE-SHIFT, USE-ROMAN, USE-OLDJIS, NO-ISO6429
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
448 ## else if TYPE = 4 then
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
449 ## comma (`,') separated CCL programs for read and write
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
450 ## else
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
451 ## 0
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
452 ## POST-READ-CONVERSION, PRE-WRITE-CONVERSION = function name to be called
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
453 ##
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
454 "))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
455 (let ((bases (coding-system-list))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
456 ;;(coding-system-list 'base-only))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
457 coding-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
458 (while bases
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
459 (setq coding-system (car bases))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
460 (if (null arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
461 (print-coding-system-briefly coding-system 'doc-string)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
462 (print-coding-system coding-system))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
463 (setq bases (cdr bases))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
464
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
465 ;;;###automatic
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
466 (defun list-coding-categories ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
467 "Display a list of all coding categories."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
468 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
469 (princ "\
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
470 ############################
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
471 ## LIST OF CODING CATEGORIES (ordered by priority)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
472 ## CATEGORY:CODING-SYSTEM
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
473 ##
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
474 ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
475 (let ((l coding-category-list))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
476 (while l
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
477 (princ (format "%s:%s\n" (car l) (symbol-value (car l))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
478 (setq l (cdr l))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
479
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
480 ;;; FONT
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
481
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
482 ;; Print information of a font in FONTINFO.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
483 (defun describe-font-internal (font-info &optional verbose)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
484 (print-list "name (opened by):" (aref font-info 0))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
485 (print-list " full name:" (aref font-info 1))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
486 (let ((charset (aref font-info 2)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
487 (print-list " charset:"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
488 (format "%s (%s)" charset (charset-description charset))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
489 (print-list " size:" (format "%d" (aref font-info 3)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
490 (print-list " height:" (format "%d" (aref font-info 4)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
491 (print-list " baseline-offset:" (format "%d" (aref font-info 5)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
492 (print-list "relative-compose:" (format "%d" (aref font-info 6))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
493
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
494 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
495 (defun describe-font (fontname)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
496 "Display information about fonts which partially match FONTNAME."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
497 (interactive "sFontname (default, current choise for ASCII chars): ")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
498 (or window-system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
499 (error "No window system being used"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
500 (when (or (not fontname) (= (length fontname) 0))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
501 (setq fontname (cdr (assq 'font (frame-parameters))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
502 (if (query-fontset fontname)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
503 (setq fontname
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
504 (nth 2 (assq 'ascii (aref (fontset-info fontname) 2))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
505 (let ((font-info (font-info fontname)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
506 (if (null font-info)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
507 (message "No matching font")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
508 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
509 (describe-font-internal font-info 'verbose)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
510
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
511 ;; Print information of FONTSET. If optional arg PRINT-FONTS is
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
512 ;; non-nil, print also names of all fonts in FONTSET. This function
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
513 ;; actually INSERT such information in the current buffer.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
514 (defun print-fontset (fontset &optional print-fonts)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
515 (let* ((fontset-info (fontset-info fontset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
516 (size (aref fontset-info 0))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
517 (height (aref fontset-info 1))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
518 (fonts (and print-fonts (aref fontset-info 2)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
519 (xlfd-fields (x-decompose-font-name fontset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
520 style)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
521 (if xlfd-fields
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
522 (let ((weight (aref xlfd-fields xlfd-regexp-weight-subnum))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
523 (slant (aref xlfd-fields xlfd-regexp-slant-subnum)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
524 (if (string-match "^bold$\\|^demibold$" weight)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
525 (setq style (concat weight " "))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
526 (setq style "medium "))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
527 (cond ((string-match "^i$" slant)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
528 (setq style (concat style "italic")))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
529 ((string-match "^o$" slant)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
530 (setq style (concat style "slant")))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
531 ((string-match "^ri$" slant)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
532 (setq style (concat style "reverse italic")))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
533 ((string-match "^ro$" slant)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
534 (setq style (concat style "reverse slant")))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
535 (setq style " ? "))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
536 (beginning-of-line)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
537 (insert fontset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
538 (indent-to 58)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
539 (insert (if (> size 0) (format "%2dx%d" size height) " -"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
540 (indent-to 64)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
541 (insert style "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
542 (when print-fonts
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
543 (insert " O Charset / Fontname\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
544 " - ------------------\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
545 (sort-charset-list)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
546 (let ((l charset-list)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
547 charset font-info opened fontname)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
548 (while l
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
549 (setq charset (car l) l (cdr l))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
550 (setq font-info (assq charset fonts))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
551 (if (null font-info)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
552 (setq opened ?? fontname "not specified")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
553 (if (nth 2 font-info)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
554 (if (stringp (nth 2 font-info))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
555 (setq opened ?o fontname (nth 2 font-info))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
556 (setq opened ?- fontname (nth 1 font-info)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
557 (setq opened ?x fontname (nth 1 font-info))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
558 (insert (format " %c %s\n %s\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
559 opened charset fontname)))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
560
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
561 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
562 (defun describe-fontset (fontset)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
563 "Display information of FONTSET.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
564
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
565 It prints name, size, and style of FONTSET, and lists up fonts
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
566 contained in FONTSET.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
567
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
568 The column WDxHT contains width and height (pixels) of each fontset
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
569 \(i.e. those of ASCII font in the fontset). The letter `-' in this
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
570 column means that the corresponding fontset is not yet used in any
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
571 frame.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
572
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
573 The O column of each font contains one of the following letters.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
574 o -- font already opened
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
575 - -- font not yet opened
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
576 x -- font can't be opened
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
577 ? -- no font specified
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
578
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
579 The Charset column of each font contains a name of character set
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
580 displayed by the font."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
581 (interactive
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
582 (if (not window-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
583 (error "No window system being used")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
584 (let ((fontset-list (mapcar '(lambda (x) (list x)) (fontset-list)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
585 (completion-ignore-case t))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
586 (list (completing-read
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
587 "Fontset (default, used by the current frame): "
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
588 fontset-list nil t)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
589 (if (= (length fontset) 0)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
590 (setq fontset (cdr (assq 'font (frame-parameters)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
591 (if (not (query-fontset fontset))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
592 (error "Current frame is using font, not fontset"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
593 (let ((fontset-info (fontset-info fontset)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
594 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
595 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
596 (set-buffer standard-output)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
597 (insert "Fontset-Name\t\t\t\t\t\t WDxHT Style\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
598 (insert "------------\t\t\t\t\t\t ----- -----\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
599 (print-fontset fontset t)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
600
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
601 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
602 (defun list-fontsets (arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
603 "Display a list of all fontsets.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
604
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
605 It prints name, size, and style of each fontset.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
606 With prefix arg, it also lists up fonts contained in each fontset.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
607 See the function `describe-fontset' for the format of the list."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
608 (interactive "P")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
609 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
610 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
611 (set-buffer standard-output)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
612 (insert "Fontset-Name\t\t\t\t\t\t WDxHT Style\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
613 (insert "------------\t\t\t\t\t\t ----- -----\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
614 (let ((fontsets (fontset-list)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
615 (while fontsets
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
616 (print-fontset (car fontsets) arg)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
617 (setq fontsets (cdr fontsets)))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
618
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
619 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
620 (defun list-input-methods ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
621 "Print information of all input methods."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
622 (interactive)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
623 (with-output-to-temp-buffer "*Help*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
624 (princ "LANGUAGE\n NAME (`TITLE' in mode line)\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
625 (princ " SHORT-DESCRIPTION\n------------------------------\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
626 (setq input-method-alist
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
627 (sort input-method-alist
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
628 (function (lambda (x y) (string< (nth 1 x) (nth 1 y))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
629 (let ((l input-method-alist)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
630 language elt)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
631 (while l
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
632 (setq elt (car l) l (cdr l))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
633 (when (not (equal language (nth 1 elt)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
634 (setq language (nth 1 elt))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
635 (princ language)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
636 (terpri))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
637 (princ (format " %s (`%s' in mode line)\n %s\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
638 (car elt) (nth 3 elt)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
639 (let ((title (nth 4 elt)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
640 (string-match ".*" title)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
641 (match-string 0 title))))))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
642
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
643 ;;; DIAGNOSIS
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
644
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
645 ;; Insert a header of a section with SECTION-NUMBER and TITLE.
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
646 (defun insert-section (section-number title)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
647 (insert "########################################\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
648 "# Section " (format "%d" section-number) ". " title "\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
649 "########################################\n\n"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
650
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
651 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
652 (defun mule-diag ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
653 "Display diagnosis of the multilingual environment (MULE).
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
654
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
655 It prints various information related to the current multilingual
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
656 environment, including lists of input methods, coding systems,
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
657 character sets, and fontsets (if Emacs running under some window
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
658 system)."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
659 (interactive)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
660 (with-output-to-temp-buffer "*Mule-Diagnosis*"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
661 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
662 (set-buffer standard-output)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
663 (insert "\t###############################\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
664 "\t### Diagnosis of your Emacs ###\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
665 "\t###############################\n\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
666 "CONTENTS: Section 1. General Information\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
667 " Section 2. Display\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
668 " Section 3. Input methods\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
669 " Section 4. Coding systems\n"
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
670 " Section 5. Character sets\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
671 (if window-system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
672 (insert " Section 6. Fontsets\n"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
673 (insert "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
674
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
675 (insert-section 1 "General Information")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
676 (insert "Version of this emacs:\n " (emacs-version) "\n\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
677
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
678 (insert-section 2 "Display")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
679 (if window-system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
680 (insert "Window-system: "
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
681 (symbol-name window-system)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
682 (format "%s" window-system-version))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
683 (insert "Terminal: " (getenv "TERM")))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
684 (insert "\n\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
685
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
686 (if (eq window-system 'x)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
687 (let ((font (cdr (assq 'font (frame-parameters)))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
688 (insert "The selected frame is using the "
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
689 (if (query-fontset font) "fontset" "font")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
690 ":\n\t" font))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
691 (insert "Coding system of the terminal: "
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
692 (symbol-name (terminal-coding-system))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
693 (insert "\n\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
694
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
695 (insert-section 3 "Input methods")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
696 (save-excursion (list-input-methods))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
697 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
698 (insert "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
699 (if default-input-method
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
700 (insert "Default input method: " default-input-method "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
701 (insert "No default input method is specified\n"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
702
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
703 (insert-section 4 "Coding systems")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
704 (save-excursion (list-coding-systems t))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
705 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
706 (save-excursion (list-coding-categories))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
707 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
708 (insert "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
709
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
710 (insert-section 5 "Character sets")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
711 (save-excursion (list-character-sets t))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
712 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
713 (insert "\n")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
714
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
715 (when window-system
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
716 (insert-section 6 "Fontsets")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
717 (save-excursion (list-fontsets t))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
718 (insert-buffer-substring "*Help*"))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
719 (help-mode))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
720
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
721
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
722 ;;; DUMP DATA FILE
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
723
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
724 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
725 (defun dump-charsets ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
726 "Dump information of all charsets into the file \"CHARSETS\".
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
727 The file is saved in the directory `data-directory'."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
728 (let ((file (expand-file-name "CHARSETS" data-directory))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
729 buf)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
730 (or (file-writable-p file)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
731 (error "Can't write to file %s" file))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
732 (setq buf (find-file-noselect file))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
733 (save-window-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
734 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
735 (set-buffer buf)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
736 (setq buffer-read-only nil)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
737 (erase-buffer)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
738 (list-character-sets t)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
739 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
740 (let (make-backup-files
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
741 coding-system-for-write)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
742 (save-buffer))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
743 (kill-buffer buf))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
744 (if noninteractive
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
745 (kill-emacs)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
746
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
747 ;;;###autoload
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
748 (defun dump-codings ()
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
749 "Dump information of all coding systems into the file \"CODINGS\".
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
750 The file is saved in the directory `data-directory'."
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
751 (let ((file (expand-file-name "CODINGS" data-directory))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
752 buf)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
753 (or (file-writable-p file)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
754 (error "Can't write to file %s" file))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
755 (setq buf (find-file-noselect file))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
756 (save-window-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
757 (save-excursion
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
758 (set-buffer buf)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
759 (setq buffer-read-only nil)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
760 (erase-buffer)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
761 (list-coding-systems t)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
762 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
763 (list-coding-categories)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
764 (insert-buffer-substring "*Help*")
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
765 (let (make-backup-files
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
766 coding-system-for-write)
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
767 (save-buffer))))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
768 (kill-buffer buf))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
769 (if noninteractive
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
770 (kill-emacs)))
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
771
e45d5e7c476e Import from CVS: tag r20-4b2
cvs
parents:
diff changeset
772 ;;; mule-diag.el ends here