annotate lisp/tl/emu-x20.el @ 90:99da576a67e7 xemacs-20-0

Import from CVS: tag xemacs-20-0
author cvs
date Mon, 13 Aug 2007 09:10:46 +0200
parents 364816949b59
children 0d2f883870bc
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>
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
6 ;; Version: $Id: emu-x20.el,v 1.3 1997/01/30 02:22:46 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
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
26 ;;; Code:
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
27
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
28 (require 'cyrillic)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
29 (require 'emu-xemacs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
30
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
31 (defvar xemacs-beta-version
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
32 (if (string-match "(beta\\([0-9]+\\))" emacs-version)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
33 (string-to-number
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
34 (substring emacs-version (match-beginning 1)(match-end 1))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
35 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
36
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
37
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
38 ;;; @ coding-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
39 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
40
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
41 (defconst *noconv* 'no-conversion)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
42 (defconst *ctext* 'ctext)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
43 (defconst *hz* 'hz)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
44 (defconst *big5* 'big5)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
45 (defconst *euc-kr* 'euc-kr)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
46 (defconst *koi8* 'koi8)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
47
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
48 (defalias 'set-buffer-file-coding-system 'set-file-coding-system)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
49
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
50 (defmacro as-binary-process (&rest body)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
51 `(let (selective-display ; Disable ^M to nl translation.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
52 process-input-coding-system
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
53 process-output-coding-system)
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
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
56 (defmacro as-binary-input-file (&rest body)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
57 `(let ((file-coding-system-for-read 'no-conversion))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
58 ,@body))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
59
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
60
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
61 ;;; @ MIME charset
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
62 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
63
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
64 (defvar charsets-mime-charset-alist
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
65 '(((ascii) . us-ascii)
74
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
66 ((ascii latin-iso8859-1) . iso-8859-1)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
67 ((ascii latin-iso8859-2) . iso-8859-2)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
68 ((ascii latin-iso8859-3) . iso-8859-3)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
69 ((ascii latin-iso8859-4) . iso-8859-4)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
70 ;;; ((ascii cyrillic-iso8859-5) . iso-8859-5)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
71 ((ascii cyrillic-iso8859-5) . koi8-r)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
72 ((ascii arabic-iso8859-6) . iso-8859-6)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
73 ((ascii greek-iso8859-7) . iso-8859-7)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
74 ((ascii hebrew-iso8859-8) . iso-8859-8)
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
75 ((ascii latin-iso8859-9) . iso-8859-9)
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
76 ((ascii latin-jisx0201
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
77 japanese-jisx0208-1978 japanese-jisx0208) . iso-2022-jp)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
78 ((ascii korean-ksc5601) . euc-kr)
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
79 ((ascii chinese-gb2312) . cn-gb-2312)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
80 ((ascii chinese-big5-1 chinese-big5-2) . cn-big5)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
81 ((ascii latin-iso8859-1 greek-iso8859-7
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
82 latin-jisx0201 japanese-jisx0208-1978
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
83 chinese-gb2312 japanese-jisx0208
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
84 korean-ksc5601 japanese-jisx0212) . iso-2022-jp-2)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
85 ((ascii latin-iso8859-1 greek-iso8859-7
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
86 latin-jisx0201 japanese-jisx0208-1978
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
87 chinese-gb2312 japanese-jisx0208
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
88 korean-ksc5601 japanese-jisx0212
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
89 chinese-cns11643-1 chinese-cns11643-2) . iso-2022-int-1)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
90 ((ascii latin-iso8859-1 latin-iso8859-2
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
91 cyrillic-iso8859-5 greek-iso8859-7
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
92 latin-jisx0201 japanese-jisx0208-1978
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
93 chinese-gb2312 japanese-jisx0208
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
94 korean-ksc5601 japanese-jisx0212
74
54cc21c15cbb Import from CVS: tag r20-0b32
cvs
parents: 70
diff changeset
95 chinese-cns11643-1 chinese-cns11643-2
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
96 chinese-cns11643-3 chinese-cns11643-4
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
97 chinese-cns11643-5 chinese-cns11643-6
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
98 chinese-cns11643-7) . iso-2022-int-1)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
99 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
100
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
101 (defvar default-mime-charset 'x-ctext)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
102
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
103 (defvar mime-charset-coding-system-alist
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
104 '((iso-8859-1 . ctext)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
105 (x-ctext . ctext)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
106 (hz-gb-2312 . hz)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
107 (cn-gb-2312 . euc-china)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
108 (gb2312 . euc-china)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
109 (cn-big5 . big5)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
110 (koi8-r . koi8)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
111 (iso-2022-jp-2 . iso-2022-ss2-7)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
112 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
113
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
114 (defun mime-charset-to-coding-system (charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
115 "Return coding-system by MIME charset. [emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
116 (if (stringp charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
117 (setq charset (intern (downcase charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
118 )
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
119 (or (cdr (assq charset mime-charset-coding-system-alist))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
120 (and (memq charset (coding-system-list)) charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
121 ))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
122
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
123 (defun detect-mime-charset-region (start end)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
124 "Return MIME charset for region between START and END.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
125 \[emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
126 (charsets-to-mime-charset (charsets-in-region start end)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
127
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
128 (defun encode-mime-charset-region (start end charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
129 "Encode the text between START and END as MIME CHARSET.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
130 \[emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
131 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
132 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
133 (encode-coding-region start end cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
134 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
135
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
136 (defun decode-mime-charset-region (start end charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
137 "Decode the text between START and END as MIME CHARSET.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
138 \[emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
139 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
140 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
141 (decode-coding-region start end cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
142 )))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
143
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
144 (defun encode-mime-charset-string (string charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
145 "Encode the STRING as MIME CHARSET. [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-string string cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
149 string)))
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-string (string charset)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
152 "Decode the STRING as MIME CHARSET. [emu-x20.el]"
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
153 (let ((cs (mime-charset-to-coding-system charset)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
154 (if cs
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
155 (decode-coding-string string cs)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
156 string)))
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 ;;; @ character
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
160 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
161
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
162 ;; (defun char-bytes (chr) 1)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
163
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
164 ;; (defun char-length (character)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
165 ;; "Return number of elements a CHARACTER occupies in a string or buffer.
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
166 ;; \[emu-x20.el]"
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
167 ;; 1)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
168
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
169 ;; (defun char-columns (character)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
170 ;; "Return number of columns a CHARACTER occupies when displayed.
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
171 ;; \[emu-x20.el]"
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
172 ;; (charset-columns (char-charset character))
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
173 ;; )
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
174
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
175 ;;; @@ Mule emulating aliases
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
176 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
177 ;;; You should not use them.
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
178
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
179 ;;(defalias 'char-width 'char-columns)
70
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
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
198 ;; (defun string-columns (string)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
199 ;; "Return number of columns STRING occupies when displayed.
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
200 ;; \[emu-x20.el]"
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
201 ;; (let ((col 0)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
202 ;; (len (length string))
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
203 ;; (i 0))
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
204 ;; (while (< i len)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
205 ;; (setq col (+ col (char-columns (aref string i))))
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
206 ;; (setq i (1+ i))
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
207 ;; )
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
208 ;; col))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
209
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
210 ;;(defalias 'string-width 'string-columns)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
211
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
212 (defun string-to-int-list (str)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
213 (mapcar #'char-int str)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
214 )
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
215
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
216 ;;(defalias 'sref 'aref)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
217
86
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
218 ;; (defun truncate-string (str width &optional start-column)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
219 ;; "Truncate STR to fit in WIDTH columns.
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
220 ;; Optional non-nil arg START-COLUMN specifies the starting column.
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
221 ;; \[emu-x20.el; Mule 2.3 emulating function]"
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
222 ;; (or start-column
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
223 ;; (setq start-column 0))
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
224 ;; (substring str start-column width)
364816949b59 Import from CVS: tag r20-0b93
cvs
parents: 82
diff changeset
225 ;; )
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
226
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
227
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
228 ;;; @ end
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
229 ;;;
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
230
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
231 (provide 'emu-x20)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
232
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents:
diff changeset
233 ;;; emu-x20.el ends here