annotate lisp/mule/mule-debug.el @ 223:2c611d1463a6 r20-4b10

Import from CVS: tag r20-4b10
author cvs
date Mon, 13 Aug 2007 10:10:54 +0200
parents e45d5e7c476e
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
1 ;;; mule-diag.el --- debugging functions for Mule.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
2
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
3 ;; Copyright (C) 1992 Free Software Foundation, Inc.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
4 ;; Copyright (C) 1995 Sun Microsystems.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
5
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
6 ;; This file is part of XEmacs.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
7
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
8 ;; XEmacs is free software; you can redistribute it and/or modify it
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
9 ;; under the terms of the GNU General Public License as published by
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
10 ;; the Free Software Foundation; either version 2, or (at your option)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
11 ;; any later version.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
12
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
13 ;; XEmacs is distributed in the hope that it will be useful, but
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
14 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
15 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
16 ;; General Public License for more details.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
17
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
18 ;; You should have received a copy of the GNU General Public License
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
19 ;; along with XEmacs; see the file COPYING. If not, write to the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
20 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
21 ;; Boston, MA 02111-1307, USA.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
22
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
23 ;;; 93.7.28 created for Mule Ver.0.9.8 by K.Handa <handa@etl.go.jp>
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
24
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
25 ;;; General utility function
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
26
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
27 (defun mule-debug-princ-list (&rest args)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
28 (while (cdr args)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
29 (if (car args)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
30 (progn (princ (car args)) (princ " ")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
31 (setq args (cdr args)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
32 (princ (car args))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
33 (princ "\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
34
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
35 ;;; character sets
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
36
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
37 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
38 (defun list-charsets ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
39 "Display a list of existing character sets."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
40 (interactive)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
41 (with-output-to-temp-buffer "*Charset List*"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
42 (princ "## LIST OF CHARACTER SETS\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
43 (princ
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
44 "NAME REGISTRY BYTES CHARS FINAL GRAPHIC DIR\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
45 (princ
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 207
diff changeset
46 "--------------------------------------------------------------------\n")
102
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
47 (dolist (charset (charset-list))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
48 (setq charset (get-charset charset))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
49 (princ (format
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 207
diff changeset
50 "%-20.20s %-15.15s %5d %5d %5d %-7d %s\n"
102
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
51 (charset-name charset)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
52 (charset-registry charset)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
53 (charset-dimension charset)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
54 (charset-chars charset)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
55 (charset-final charset)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
56 (charset-graphic charset)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
57 (charset-direction charset)))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
58 (princ " ")
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 207
diff changeset
59 (princ (format "%s\n" (charset-doc-string charset))))))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
60
102
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
61 ; (princ "## CCL PROGRAM TO CONVERT INTERNAL TO EXTERNAL CODE\n")
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
62 ; (princ "NAME CCL-PROGRAMS\n")
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
63 ; (mapcar
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
64 ; (lambda (name)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
65 ; (let ((ccl (charset-ccl-program name)))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
66 ; (if ccl
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
67 ; (let ((i 0) (len (length ccl)))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
68 ; (princ (format "%20s " name))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
69 ; (while (< i len)
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
70 ; (princ (format " %x" (aref ccl i)))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
71 ; (setq i (1+ i)))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
72 ; (princ "\n")))))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
73 ; (charset-list))
a145efe76779 Import from CVS: tag r20-1b3
cvs
parents: 70
diff changeset
74 ; ))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
75
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
76 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
77 (defun list-coding-system-briefly ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
78 "Display coding-systems currently used with a brief format in mini-buffer."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
79 (interactive)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
80 (let ((cs (and (fboundp 'process-coding-system) (process-coding-system)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
81 eol-type)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
82 (message
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
83 "current: [FKDPp=%c%c%c%c%c%c%c%c] default: [FPp=%c%c%c%c%c%c]"
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
84 (coding-system-mnemonic buffer-file-coding-system)
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
85 (coding-system-eol-mnemonic buffer-file-coding-system)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
86 (coding-system-mnemonic keyboard-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
87 (coding-system-mnemonic terminal-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
88 (coding-system-mnemonic (car cs))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
89 (coding-system-eol-mnemonic (car cs))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
90 (coding-system-mnemonic (cdr cs))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
91 (coding-system-eol-mnemonic (cdr cs))
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
92 (coding-system-mnemonic (default-value 'buffer-file-coding-system))
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
93 (coding-system-eol-mnemonic (default-value 'buffer-file-coding-system))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
94 (coding-system-mnemonic (car default-process-coding-system))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
95 (coding-system-eol-mnemonic (car default-process-coding-system))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
96 (coding-system-mnemonic (cdr default-process-coding-system))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
97 (coding-system-eol-mnemonic (cdr default-process-coding-system))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
98 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
99
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
100 (defun princ-coding-system (code)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
101 (princ ": ")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
102 (princ code)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
103 (princ " [")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
104 (princ (char-to-string (coding-system-mnemonic code)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
105 (princ (char-to-string (coding-system-eol-mnemonic code)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
106 (princ "]\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
107
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
108 (defun todigit (flags idx &optional default-value)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
109 (if (aref flags idx)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
110 (if (numberp (aref flags idx)) (aref flags idx) 1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
111 (or default-value 0)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
112
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
113 (defun print-coding-system-description (code)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
114 (let ((type (get-code-type code))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
115 (eol (or (get-code-eol code) 1))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
116 (flags (get-code-flags code))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
117 line)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
118 (setq type
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
119 (cond ((null type) 0)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
120 ((eq type t) 2)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
121 ((eq type 0) 1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
122 ((eq type 1) 3)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
123 ((eq type 2) 4)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
124 ((eq type 3) 5)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
125 ((eq type 4) 6)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
126 (t nil)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
127 (if (or (null type)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
128 (get code 'post-read-conversion)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
129 (get (get-base-code code) 'post-read-conversion)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
130 (get code 'pre-write-conversion)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
131 (get (get-base-code code) 'pre-write-conversion)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
132 (eq code '*noconv*))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
133 nil
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
134 (princ
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
135 (format "%s:%d:%c:"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
136 code type (coding-system-mnemonic code)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
137 (princ (format "%d" (if (numberp eol) eol 0)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
138 (cond ((= type 4)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
139 (princ
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
140 (format
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
141 ":%d,%d,%d,%d,%d,%d,%d,%d,%d,%d,%d,%d"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
142 (todigit flags 0 -1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
143 (todigit flags 1 -1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
144 (todigit flags 2 -1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
145 (todigit flags 3 -1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
146 (todigit flags 4)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
147 (todigit flags 5)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
148 (todigit flags 6)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
149 (todigit flags 7)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
150 (todigit flags 8)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
151 (todigit flags 9)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
152 (todigit flags 10)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
153 (todigit flags 11))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
154 ((= type 5)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
155 (princ ":0"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
156 ((= type 6)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
157 (if (and (vectorp (car flags)) (vectorp (cdr flags)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
158 (let (i len)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
159 (princ ":")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
160 (setq i 0 len (length (car flags)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
161 (while (< i len)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
162 (princ (format " %x" (aref (car flags) i)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
163 (setq i (1+ i)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
164 (princ ",")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
165 (setq i 0 len (length (cdr flags)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
166 (while (< i len)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
167 (princ (format " %x" (aref (cdr flags) i)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
168 (setq i (1+ i))))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
169 (t (princ ":0")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
170 (princ ":")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
171 (princ (get-code-document code))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
172 (princ "\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
173 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
174
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
175 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
176 (defun list-coding-system (&optional all)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
177 "Describe coding-systems currently used with a detailed format.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
178 If optional arg ALL is non-nil, all coding-systems are listed in
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
179 machine readable simple format."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
180 (interactive "P")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
181 (with-output-to-temp-buffer "*Help*"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
182 (if (null all)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
183 (let ((cs (and (fboundp 'process-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
184 (process-coding-system))))
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
185 (princ "Current:\n buffer-file-coding-system")
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
186 (princ-coding-system buffer-file-coding-system)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
187 (princ " keyboard-coding-system")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
188 (princ-coding-system keyboard-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
189 (princ " terminal-coding-system")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
190 (princ-coding-system terminal-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
191 (when cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
192 (princ " process-coding-system (input)")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
193 (princ-coding-system (car cs))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
194 (princ " process-coding-system (output)")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
195 (princ-coding-system (cdr cs)))
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
196 (princ "Default:\n buffer-file-coding-system")
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
197 (princ-coding-system (default-value 'buffer-file-coding-system))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
198 (princ " process-coding-system (input)")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
199 (princ-coding-system (car default-process-coding-system))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
200 (princ " process-coding-system (output)")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
201 (princ-coding-system (cdr default-process-coding-system))
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
202 (princ "Others:\n buffer-file-coding-system-for-read")
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 102
diff changeset
203 (princ-coding-system buffer-file-coding-system-for-read)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
204 (princ "Coding categories by priority:\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
205 (princ (coding-priority-list)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
206 (princ "########################\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
207 (princ "## LIST OF CODING SYSTEM\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
208 (princ "## NAME(str):TYPE(int):MNEMONIC(char):EOL(int):FLAGS:DOC(str)\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
209 (princ "## TYPE = 0(no conversion),1(auto conversion),\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
210 (princ "## 2(Mule internal),3(SJIS),4(ISO2022),5(BIG5),6(CCL)\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
211 (princ "## EOL = 0(AUTO), 1(LF), 2(CRLF), 3(CR)\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
212 (princ "## FLAGS =\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
213 (princ "## if TYPE = 4 then\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
214 (princ "## G0,G1,G2,G3,SHORT,ASCII-EOL,ASCII-CNTL,SEVEN,\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
215 (princ "## LOCK-SHIFT,USE-ROMAN,USE-OLDJIS\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
216 (princ "## else if TYPE = 6 then\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
217 (princ "## CCL_PROGRAM_FOR_READ,CCL_PROGRAM_FOR_WRITE\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
218 (princ "## else\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
219 (princ "## 0\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
220 (princ "##\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
221 (let ((codings nil))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
222 (mapatoms
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
223 (function
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
224 (lambda (arg)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
225 (if (eq arg '*noconv*)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
226 nil
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
227 (if (and (or (vectorp (get arg 'coding-system))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
228 (vectorp (get arg 'eol-type)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
229 (null (get arg 'pre-write-conversion))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
230 (null (get arg 'post-read-conversion)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
231 (setq codings (cons arg codings)))))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
232 (while codings
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
233 (print-coding-system-description (car codings))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
234 (setq codings (cdr codings))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
235 (princ "############################\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
236 (princ "## LIST OF CODING CATEGORIES (ordered by priority)\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
237 (princ "## CATEGORY(str):CODING-SYSTEM(str)\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
238 (princ "##\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
239 (princ (coding-priority-list))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
240 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
241
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
242 ;;; FONT
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
243 (defun describe-font-internal (fontinfo &optional verbose)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
244 (let ((cs (character-set (aref fontinfo 3))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
245 (mule-debug-princ-list (format "Font #%02d for" (aref fontinfo 0))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
246 (nth 6 cs) (nth 7 cs) "--"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
247 (cond ((= (aref fontinfo 4) 0) "NOT YET OPENED")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
248 ((= (aref fontinfo 4) 1) "OPENED")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
249 (t "NOT FOUND")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
250 (mule-debug-princ-list " request:" (aref fontinfo 1))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
251 (if (= (aref fontinfo 4) 1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
252 (mule-debug-princ-list " opened:" (aref fontinfo 2)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
253 (if (and verbose (= (aref fontinfo 4) 1))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
254 (progn
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
255 (mule-debug-princ-list " size:" (format "%d" (aref fontinfo 5)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
256 (mule-debug-princ-list " encoding:" (if (= (aref fontinfo 6) 0) "low" "high"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
257 (mule-debug-princ-list " yoffset:" (format "%d" (aref fontinfo 7)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
258 (mule-debug-princ-list " rel-cmp:" (format "%d" (aref fontinfo 8)))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
259 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
260
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
261 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
262 (defun describe-font (fontname)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
263 "Display information about fonts which partially match FONTNAME."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
264 (interactive "sFontname: ")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
265 (setq fontname (regexp-quote fontname))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
266 (with-output-to-temp-buffer "*Help*"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
267 (let ((fontlist (font-list)) fontinfo)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
268 (while fontlist
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
269 (setq fontinfo (car fontlist))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
270 (if (or (string-match fontname (aref fontinfo 1))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
271 (and (aref fontinfo 2)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
272 (string-match fontname (aref fontinfo 2))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
273 (describe-font-internal fontinfo 'verbose))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
274 (setq fontlist (cdr fontlist))))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
275
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
276 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
277 (defun list-font ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
278 "Display a list of fonts."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
279 (interactive)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
280 (with-output-to-temp-buffer "*Help*"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
281 (let ((fontlist (font-list)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
282 (while fontlist
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
283 (describe-font-internal (car fontlist))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
284 (setq fontlist (cdr fontlist))))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
285
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
286 ;;; FONTSET
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
287 (defun describe-fontset-internal (fontset-info)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
288 (mule-debug-princ-list "### Fontset-name:" (car fontset-info) "###")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
289 (let ((i 0) font)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
290 (while (< i 128)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
291 (if (>= (setq font (aref (cdr fontset-info) i)) 0)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
292 (describe-font-internal (get-font-info font)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
293 (setq i (1+ i)))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
294
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
295 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
296 (defun describe-fontset (fontset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
297 "Display information about FONTSET."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
298 (interactive
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
299 (let ((fontset-list (mapcar '(lambda (x) (list x)) (fontset-list))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
300 (list (completing-read "Fontset: " fontset-list nil 'match))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
301 (let ((fontset-info (get-fontset-info fontset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
302 (if fontset-info
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
303 (with-output-to-temp-buffer "*Help*"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
304 (describe-fontset-internal fontset-info))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
305 (error "No such fontset: %s" fontset))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
306
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
307 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
308 (defun list-fontset ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
309 "Display a list of fontsets."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
310 (interactive)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
311 (with-output-to-temp-buffer "*Help*"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
312 (let ((fontsetlist (fontset-list 'all)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
313 (while fontsetlist
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
314 (describe-fontset-internal (car fontsetlist))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
315 (setq fontsetlist (cdr fontsetlist))))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
316
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
317 ;;; DIAGNOSIS
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
318
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
319 (defun insert-list (args)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
320 (while (cdr args)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
321 (insert (or (car args) "nil") " ")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
322 (setq args (cdr args)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
323 (if args (insert (or (car args) "nil")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
324 (insert "\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
325
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
326 (defun insert-section (sec title)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
327 (insert "########################################\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
328 "# Section " (format "%d" sec) ". " title "\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
329 "########################################\n\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
330
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
331 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
332 (defun mule-diag ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
333 "Show diagnosis of the current running Mule."
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
334 (interactive)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
335 (let ((buf (get-buffer-create "*Diagnosis*")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
336 (save-excursion
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
337 (set-buffer buf)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
338 (erase-buffer)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
339 (insert "\t##############################\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
340 "\t### DIAGNOSIS OF YOUR MULE ###\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
341 "\t##############################\n\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
342 "CONTENTS: Section 0. General information\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
343 " Section 1. Display\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
344 " Section 2. Input methods\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
345 " Section 3. Coding-systems\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
346 " Section 4. Character sets\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
347 (if window-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
348 (insert " Section 5. Fontset list\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
349 (insert "\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
350
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
351 (insert-section 0 "General information")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
352 (insert "Mule's version: " mule-version " of " mule-version-date "\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
353 (if window-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
354 (insert "Window-system: "
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
355 (symbol-name window-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
356 (format "%s" window-system-version))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
357 (insert "Terminal: " (getenv "TERM")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
358 (insert "\n\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
359
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
360 (insert-section 1 "Display")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
361 (if (eq window-system 'x)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
362 (let* ((alist (nth 1 (assq (selected-frame)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
363 (current-frame-configuration))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
364 (fontset (cdr (assq 'font alist))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
365 (insert-list (cons "Defined fontsets:" (fontset-list)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
366 (insert "Current frame's fontset: " fontset "\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
367 "See Section 5 for more detail.\n\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
368 (insert "Coding system for output to terminal: "
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
369 (symbol-name terminal-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
370 "\n\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
371 (insert-section 2 "Input methods")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
372 (if (featurep 'egg)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
373 (let (temp)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
374 (insert "EGG (Version " egg-version ")\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
375 (insert " jserver host list: ")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
376 (insert-list (if (boundp 'jserver-list) jserver-list
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
377 (if (setq temp (getenv "JSERVER"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
378 (list temp))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
379 (insert " cserver host list: ")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
380 (insert-list (if (boundp 'cserver-list) cserver-list
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
381 (if (setq temp (getenv "CSERVER"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
382 (list temp))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
383 (insert " loaded ITS mode:\n\t")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
384 (insert-list (mapcar 'car its:*mode-alist*))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
385 (insert " current server:" (symbol-name wnn-server-type) "\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
386 " current ITS mode:"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
387 (let ((mode its:*mode-alist*))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
388 (while (not (eq (cdr (car mode)) its:*current-map*))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
389 (setq mode (cdr mode)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
390 (car (car mode))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
391 (insert "\n")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
392 (insert "QUAIL (Version " quail-version ")\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
393 (insert " Quail packages: (not-yet-loaded) [current]\n\t")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
394 (let ((l quail-package-alist)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
395 (current (or (car quail-current-package) "")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
396 (while l
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
397 (cond ((string= current (car (car l)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
398 (insert "[" (car (car l)) "]"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
399 ((nth 2 (car l))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
400 (insert (car (car l))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
401 (t
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
402 (insert "(" (car (car l)) ")")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
403 (if (setq l (cdr l)) (insert " ") (insert "\n"))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
404 (if (featurep 'canna)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
405 (insert "CANNA (Version " canna-rcs-version ")\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
406 " server:" (or canna-server "Not specified") "\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
407 (if (featurep 'sj3-egg)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
408 (insert "SJ3 (Version" sj3-egg-version ")\n"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
409 " server:" (get-sj3-host-name) "\n"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
410 (insert "\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
411
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
412 (insert-section 3 "Coding systems")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
413 (save-excursion (list-coding-systems))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
414 (insert-buffer "*Help*")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
415 (goto-char (point-max))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
416 (insert "\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
417
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
418 (insert-section 4 "Character sets")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
419 (save-excursion (list-charsets))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
420 (insert-buffer "*Help*")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
421 (goto-char (point-max))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
422 (insert "\n")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
423
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
424 (if window-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
425 (progn
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
426 (insert-section 5 "Fontset list")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
427 (save-excursion (list-fontset))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
428 (insert-buffer "*Help*")))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
429
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
430 (set-buffer-modified-p nil)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
431 )
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
432 (let ((win (display-buffer buf)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
433 (set-window-point win 1)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
434 (set-window-start win 1))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
435 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
436
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
437 ;;; DUMP DATA FILE
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
438
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
439 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
440 (defun dump-charsets ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
441 (list-charsets)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
442 (set-buffer (get-buffer "*Help*"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
443 (let (make-backup-files)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
444 (write-region (point-min) (point-max) "charsets.lst"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
445 (kill-emacs))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
446
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
447 ;;;###autoload
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
448 (defun dump-coding-systems ()
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
449 (list-coding-systems 'all)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
450 (set-buffer (get-buffer "*Help*"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
451 (let (make-backup-files)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
452 (write-region (point-min) (point-max) "coding-systems.lst"))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
453 (kill-emacs))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
454