annotate lisp/tl/emu-x20.el @ 110:fe104dbd9147 r20-1b7

Import from CVS: tag r20-1b7
author cvs
date Mon, 13 Aug 2007 09:19:45 +0200
parents 0d2f883870bc
children 8619ce7e4c50
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 ;;; emu-x20.el --- emu API implementation for XEmacs 20 with mule
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
2
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
3 ;; Copyright (C) 1994,1995,1996,1997 MORIOKA Tomohiko
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
4
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
5 ;; Author: MORIOKA Tomohiko <morioka@jaist.ac.jp>
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
6 ;; Version: $Id: emu-x20.el,v 1.5 1997/03/16 03:05:43 steve Exp $
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
7 ;; Keywords: emulation, compatibility, Mule, XEmacs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
8
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
9 ;; This file is part of XEmacs.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
10
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
11 ;; This program is free software; you can redistribute it and/or
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
12 ;; modify it under the terms of the GNU General Public License as
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
13 ;; published by the Free Software Foundation; either version 2, or (at
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
14 ;; your option) any later version.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
15
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
16 ;; This program is distributed in the hope that it will be useful, but
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
17 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
19 ;; General Public License for more details.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
20
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
22 ;; along with GNU XEmacs; see the file COPYING. If not, write to the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
24 ;; Boston, MA 02111-1307, USA.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
25
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
26 ;;; Commentary:
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
27
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
28 ;; This module requires XEmacs 20.1 b6 or later with mule.
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
29
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
30 ;;; Commentary:
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
31
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
32 ;; This module requires XEmacs 20.1 b6 or later with mule.
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
33
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
34 ;;; Code:
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
35
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
36 (require 'cyrillic)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
37 (require 'emu-xemacs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
38
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
39
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
40 ;;; @ coding-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
41 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
42
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
43 (defconst *noconv* 'no-conversion)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
44
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
45 (defmacro as-binary-process (&rest body)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
46 `(let (selective-display ; Disable ^M to nl translation.
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
47 (coding-system-for-write 'no-conversion)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
48 process-input-coding-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
49 process-output-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
50 ,@body))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
51
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
52 (defmacro as-binary-input-file (&rest body)
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
53 `(let ((coding-system-for-read 'no-conversion))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
54 ,@body))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
55
98
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
56 (defmacro as-binary-output-file (&rest body)
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
57 `(let ((coding-system-for-write 'no-conversion))
98
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
58 ,@body))
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
59
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
60
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
61 ;;; @ binary access
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
62 ;;;
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
63
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
64 (defun insert-binary-file-contents-literally
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
65 (filename &optional visit beg end replace)
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
66 "Like `insert-file-contents-literally', q.v., but don't code conversion.
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
67 A buffer may be modified in several ways after reading into the buffer due
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
68 to advanced Emacs features, such as file-name-handlers, format decoding,
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
69 find-file-hooks, etc.
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
70 This function ensures that none of these modifications will take place."
110
fe104dbd9147 Import from CVS: tag r20-1b7
cvs
parents: 98
diff changeset
71 (let ((coding-system-for-read 'no-conversion))
98
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
72 (insert-file-contents-literally filename visit beg end replace)
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
diff changeset
73 ))
0d2f883870bc Import from CVS: tag r20-1b1
cvs
parents: 86
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 ;;; @ MIME charset
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
77 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
78
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
79 (defvar charsets-mime-charset-alist
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
80 '(((ascii) . us-ascii)
74
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
81 ((ascii latin-iso8859-1) . iso-8859-1)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
82 ((ascii latin-iso8859-2) . iso-8859-2)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
83 ((ascii latin-iso8859-3) . iso-8859-3)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
84 ((ascii latin-iso8859-4) . iso-8859-4)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
85 ;;; ((ascii cyrillic-iso8859-5) . iso-8859-5)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
86 ((ascii cyrillic-iso8859-5) . koi8-r)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
87 ((ascii arabic-iso8859-6) . iso-8859-6)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
88 ((ascii greek-iso8859-7) . iso-8859-7)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
89 ((ascii hebrew-iso8859-8) . iso-8859-8)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
90 ((ascii latin-iso8859-9) . iso-8859-9)
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
91 ((ascii latin-jisx0201
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
92 japanese-jisx0208-1978 japanese-jisx0208) . iso-2022-jp)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
93 ((ascii korean-ksc5601) . euc-kr)
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
94 ((ascii chinese-gb2312) . cn-gb-2312)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
95 ((ascii chinese-big5-1 chinese-big5-2) . cn-big5)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
96 ((ascii latin-iso8859-1 greek-iso8859-7
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
97 latin-jisx0201 japanese-jisx0208-1978
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
98 chinese-gb2312 japanese-jisx0208
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
99 korean-ksc5601 japanese-jisx0212) . iso-2022-jp-2)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
100 ((ascii latin-iso8859-1 greek-iso8859-7
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
101 latin-jisx0201 japanese-jisx0208-1978
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
102 chinese-gb2312 japanese-jisx0208
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
103 korean-ksc5601 japanese-jisx0212
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
104 chinese-cns11643-1 chinese-cns11643-2) . iso-2022-int-1)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
105 ((ascii latin-iso8859-1 latin-iso8859-2
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
106 cyrillic-iso8859-5 greek-iso8859-7
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
107 latin-jisx0201 japanese-jisx0208-1978
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
108 chinese-gb2312 japanese-jisx0208
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
109 korean-ksc5601 japanese-jisx0212
74
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
110 chinese-cns11643-1 chinese-cns11643-2
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
111 chinese-cns11643-3 chinese-cns11643-4
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
112 chinese-cns11643-5 chinese-cns11643-6
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
113 chinese-cns11643-7) . iso-2022-int-1)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
114 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
115
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
116 (defvar default-mime-charset 'x-ctext)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
117
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
118 (defvar mime-charset-coding-system-alist
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
119 '((iso-8859-1 . ctext)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
120 (x-ctext . ctext)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
121 (hz-gb-2312 . hz)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
122 (cn-gb-2312 . euc-china)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
123 (gb2312 . euc-china)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
124 (cn-big5 . big5)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
125 (koi8-r . koi8)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
126 (iso-2022-jp-2 . iso-2022-ss2-7)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
127 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
128
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
129 (defun mime-charset-to-coding-system (charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
130 "Return coding-system by MIME charset. [emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
131 (if (stringp charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
132 (setq charset (intern (downcase charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
133 )
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
134 (or (cdr (assq charset mime-charset-coding-system-alist))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
135 (and (memq charset (coding-system-list)) charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
136 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
137
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
138 (defun detect-mime-charset-region (start end)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
139 "Return MIME charset for region between START and END.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
140 \[emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
141 (charsets-to-mime-charset (charsets-in-region start end)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
142
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
143 (defun encode-mime-charset-region (start end charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
144 "Encode the text between START and END as MIME CHARSET.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
145 \[emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
146 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
147 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
148 (encode-coding-region start end cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
149 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
150
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
151 (defun decode-mime-charset-region (start end charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
152 "Decode the text between START and END as MIME CHARSET.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
153 \[emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
154 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
155 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
156 (decode-coding-region start end cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
157 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
158
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
159 (defun encode-mime-charset-string (string charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
160 "Encode the STRING as MIME CHARSET. [emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
161 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
162 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
163 (encode-coding-string string cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
164 string)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
165
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
166 (defun decode-mime-charset-string (string charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
167 "Decode the STRING as MIME CHARSET. [emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
168 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
169 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
170 (decode-coding-string string cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
171 string)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
172
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
173
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
174 ;;; @ character
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
175 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
176
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
177 ;;; @@ Mule emulating aliases
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
178 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
179 ;;; You should not use them.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
180
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
181 (defalias 'char-leading-char 'char-charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
182
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
183 (defun char-category (character)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
184 "Return string of category mnemonics for CHAR in TABLE.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
185 CHAR can be any multilingual character
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
186 TABLE defaults to the current buffer's category table.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
187 \[emu-x20.el; Mule emulating function]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
188 (mapconcat (lambda (chr)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
189 (char-to-string (int-char chr))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
190 )
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
191 (char-category-list character)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
192 ""))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
193
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
194
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
195 ;;; @ string
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
196 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
197
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
198 (defun string-to-int-list (str)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
199 (mapcar #'char-int str)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
200 )
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
201
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
202
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
203 ;;; @ end
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
204 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
205
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
206 (provide 'emu-x20)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
207
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
208 ;;; emu-x20.el ends here