(default-coded-charset-priority-list): Add `ucs' in UTF-2000.
[chise/xemacs-chise.git] / src / ChangeLog
1 2000-01-27  MORIOKA Tomohiko  <tomo@m17n.org>
2
3         * mule-charset.c (charset_code_point): Moved to char-ucs.h.
4
5         * char-ucs.h (charset_code_point): Moved from mule-charset.c.
6         (ENCODE_CHAR): New macro.
7
8 2000-01-26  MORIOKA Tomohiko  <tomo@etl.go.jp>
9
10         * mule-charset.c (vars_of_mule_charset): Update `utf-2000-version'
11         to 0.14 (Kawachi-Katakami).
12
13 2000-01-26  MORIOKA Tomohiko  <tomo@etl.go.jp>
14
15         * text-coding.c (char_encode_shift_jis): Modify for
16         `charset_code_point'.
17         (char_encode_iso2022): Likewise.
18
19         * mule-charset.c (Fput_char_attribute): Use <Lisp_Object>
20         (integer) instead of list of <Lisp_Object>s (integers) as the
21         format of code-point of a coded-charset.
22         (range_charset_code_point): Return <int> instead of <Lisp_Object>.
23         (encode_builtin_char_1): New function; delete
24         `split_builtin_char'.
25         (charset_code_point): Return <int> instead of <Lisp_Object>.
26         (Fsplit_char): Don't use `SPLIT_CHAR'.
27
28         * char-ucs.h (encode_builtin_char_1): New prototype; delete
29         prototype for `split_builtin_char'.
30         (range_charset_code_point): Return <int> instead of <Lisp_Object>.
31         (charset_code_point): Likewise.
32         (encode_char_1): New inline function; delete `SPLIT_CHAR'.
33         (breakup_char_1): Use `encode_char_1' instead of `SPLIT_CHAR'.
34
35 2000-01-20  MORIOKA Tomohiko  <tomo@m17n.org>
36
37         * mule-charset.c (complex_vars_of_mule_charset): Don't define
38         `japanese-jisx0208-1990' in non-UTF-2000 Mule.
39
40 2000-01-11  MORIOKA Tomohiko  <tomo@etl.go.jp>
41
42         * mule-charset.c (split_builtin_char): Don't support OBS_94x94.
43
44         * char-ucs.h (MIN_CHAR_OBS_94x94): Deleted.
45         (MAX_CHAR_OBS_94x94): Deleted.
46
47 2000-01-11  MORIOKA Tomohiko  <tomo@etl.go.jp>
48
49         * mule-charset.c (split_builtin_char): Use `MAX_CHAR_BMP'.
50
51         * char-ucs.h (MAX_CHAR_BMP): New macro.
52
53 2000-01-10  MORIOKA Tomohiko  <tomo@etl.go.jp>
54
55         * text-coding.c: Sync with r21-2-24.
56
57 2000-01-08  MORIOKA Tomohiko  <tomo@etl.go.jp>
58
59         * file-coding.c: Modify for UTF-2000.
60
61 2000-01-18  MORIOKA Tomohiko  <tomo@etl.go.jp>
62
63         * mule-charset.c (vars_of_mule_charset): Update `utf-2000-version'
64         to 0.13 (Takaida).
65
66 2000-01-15  MORIOKA Tomohiko  <tomo@etl.go.jp>
67
68         * mule-charset.c (split_builtin_char): Delete builtin support for
69         `katakana-jisx0201'.
70         (complex_vars_of_mule_charset): Don't map `katakana-jisx0201' to
71         BMP area in builtin representation.
72
73         * char-ucs.h (MAKE_CHAR): Delete builtin support for
74         `Vcharset_katakana_jisx0201'.
75
76 1999-12-24  MORIOKA Tomohiko  <tomo@etl.go.jp>
77
78         * mule-charset.c (Vcharset_mojikyo_pj_[1 .. 21]): New variable.
79         (Qisolated): New variable.
80         (Qinitial): New variable.
81         (Qmedial): New variable.
82         (Qfinal): New variable.
83         (Qvertical): New variable.
84         (Qsmall): New variable.
85         (to_char_code): Use `Qisolated', `Qinitial', `Qmedial', `Qfinal',
86         `Qvertical' and `Qsmall'.
87         (Qmojikyo_pj_[1 .. 21]): New variable.
88         (syms_of_mule_charset): Add new symbols `isolated', `initial',
89         `medial', `final', `vertical', `small' and `mojikyo-pj-[1 .. 21]'.
90         (complex_vars_of_mule_charset): Add new charset `mojikyo-pj-[1
91         .. 21]'.
92
93 1999-11-23  MORIOKA Tomohiko  <tomo@etl.go.jp>
94
95         * char-ucs.h (MIN_LEADING_BYTE): Changed to -0x60.
96         (LEADING_BYTE_MOJIKYO_PJ_[1 .. 21]): New macros.
97         (MAX_LEADING_BYTE_PRIVATE): Changed to `(CHARSET_ID_OFFSET - 32)'.
98
99 1999-11-18  MORIOKA Tomohiko  <tomo@etl.go.jp>
100
101         * mule-charset.c (Vcharset_japanese_jisx0208_1990): New variable.
102         (Fdefine_char): Use Group 00 Plane 10 for non-coded variants of
103         BMP.
104         (Qjapanese_jisx0208_1990): New variable.
105         (syms_of_mule_charset): Add new symbol `Qjapanese_jisx0208_1990'.
106         (complex_vars_of_mule_charset): Add new coded-charset
107         `japanese-jisx0208-1990'.
108
109         * char-ucs.h (LEADING_BYTE_JAPANESE_JISX0208_1990): New macro.
110         (MIN_CHAR_JIS_X0208_1990): New macro.
111         (MAX_CHAR_JIS_X0208_1990): New macro.
112
113 1999-11-16  MORIOKA Tomohiko  <tomo@urania.m17n.org>
114
115         * text-coding.c (char_encode_iso2022): Output `~' if ISO 2022
116         coded-charset is not found.
117
118 1999-11-16  MORIOKA Tomohiko  <tomo@urania.m17n.org>
119
120         * mule-charset.c (Fget_char_attribute): Forgot to `CHECK_CHAR'.
121         (Fdefine_char): Use `Fmake_char'.
122
123 1999-11-15  MORIOKA Tomohiko  <tomo@urania.m17n.org>
124
125         * mule-charset.c (Vcharset_ideograph_daikanwa): New variable.
126         (Vcharset_hiragana_jisx0208): Deleted.
127         (Vcharset_katakana_jisx0208): Deleted.
128         (Qideograph_daikanwa): New variable.
129         (Qhiragana_jisx0208): Deleted.
130         (Qkatakana_jisx0208): Deleted.
131         (split_builtin_char): Split `ideograph-daikanwa'.
132         (Fsplit_char): New implementation for UTF-2000.
133         (syms_of_mule_charset): Add new symbol `ideograph-daikanwa';
134         delete symbol `hiragana-jisx0208' and `katakana-jisx0208'.
135         (complex_vars_of_mule_charset): Add new coded-charset
136         `ideograph-daikanwa'; delete coded-charset `hiragana-jisx0208' and
137         `katakana-jisx0208'.
138
139         * char-ucs.h (LEADING_BYTE_DAIKANWA): New macro.
140         (LEADING_BYTE_HIRAGANA_JISX0208): Deleted.
141         (LEADING_BYTE_KATAKANA_JISX0208): Deleted.
142         (MIN_CHAR_DAIKANWA): New macro.
143         (MAX_CHAR_DAIKANWA): New macro.
144
145 1999-11-15  MORIOKA Tomohiko  <tomo@urania.m17n.org>
146
147         * data.c (Fstring_to_number): Don't recognize floating point if
148         base is not 10.
149
150 1999-11-15  MORIOKA Tomohiko  <tomo@urania.m17n.org>
151
152         * mule-charset.c (Fput_char_attribute): Forgot to `CHECK_CHAR'.
153
154 1999-11-14  MORIOKA Tomohiko  <tomo@urania.m17n.org>
155
156         * mule-charset.c (Qsquare): New variable.
157         (to_char_code): Add `Qsquare'.
158         (syms_of_mule_charset): Add new symbol `square'.
159
160 1999-11-14  MORIOKA Tomohiko  <tomo@urania.m17n.org>
161
162         * mule-charset.c (Qcircle): New variable.
163         (to_char_code): Add `Qcircle'.
164         (syms_of_mule_charset): Add new symbol `circle'.
165
166 1999-11-14  MORIOKA Tomohiko  <tomo@urania.m17n.org>
167
168         * mule-charset.c (Qfont): New variable.
169         (to_char_code): Add `Qfont'.
170         (syms_of_mule_charset): Add new symbol `font'.
171
172 1999-11-14  MORIOKA Tomohiko  <tomo@urania.m17n.org>
173
174         * mule-charset.c (Qsub): New variable.
175         (to_char_code): Add `Qsub'.
176         (syms_of_mule_charset): Add new symbol `sub'.
177
178 1999-11-14  MORIOKA Tomohiko  <tomo@urania.m17n.org>
179
180         * mule-charset.c (Fput_char_attribute): Convert each element of
181         VALUE to GL position if ATTRIBUTE is a GR-set,
182
183 1999-11-14  MORIOKA Tomohiko  <tomo@urania.m17n.org>
184
185         * mule-charset.c (Fput_char_attribute): Allow GR code-point if a
186         coded-charset is a GR-set.
187
188 1999-11-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
189
190         * mule-charset.c (Fput_char_attribute): Check each element of
191         VALUE is a byte if ATTRIBUTE is a coded-charset or its name.
192
193 1999-11-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
194
195         * mule-charset.c (Vcharset_ethiopic_ucs): New variable in
196         UTF-2000.
197         (Qethiopic_ucs): New variable in UTF-2000.
198         (syms_of_mule_charset): Add new symbol `ethiopic-ucs' in UTF-2000.
199         (complex_vars_of_mule_charset): Add new coded-charset
200         `ethiopic-ucs' in UTF-2000.
201
202         * char-ucs.h (LEADING_BYTE_ETHIOPIC_UCS): New macro.
203         (LEADING_BYTE_HIRAGANA_JISX0208): Changed to `(CHARSET_ID_OFFSET -
204         9)'.
205         (LEADING_BYTE_KATAKANA_JISX0208): Changed to `(CHARSET_ID_OFFSET -
206         10)'.
207         (LEADING_BYTE_PRIVATE): Changed to `(CHARSET_ID_OFFSET - 11)'.
208
209 1999-11-13  MORIOKA Tomohiko  <tomo@etl.go.jp>
210
211         * mule-charset.c (Fset_charset_mapping_table): Fix problem with
212         `ascii'.
213
214 1999-11-12  MORIOKA Tomohiko  <tomo@urania.m17n.org>
215
216         * mule-charset.c (Vcharacter_variant_table): New variable.
217         (Q_ucs): New variable.
218         (Fchar_variants): New function.
219         (Fput_char_attribute): Register `->ucs' value to
220         `Vcharacter_variant_table'.
221         (syms_of_mule_charset): Add new function `char-variants' and new
222         symbol `->ucs'.
223         (vars_of_mule_charset): Setup `Vcharacter_variant_table'.
224
225 1999-11-12  MORIOKA Tomohiko  <tomo@urania.m17n.org>
226
227         * mule-charset.c (get_char_code_table): Allow negative character
228         code.
229         (put_char_code_table): Likewise.
230         (Vcharacter_composition_table): New variable.
231         (Q_decomposition): New variable.
232         (Qwide): New variable.
233         (Qnarrow): New variable.
234         (Qcompat): New variable.
235         (QnoBreak): New variable.
236         (Qsuper): New variable.
237         (Qfraction): New variable.
238         (to_char_code): New function.
239         (Fget_composite_char): New function.
240         (Fput_char_attribute): Register `->decomposition' value to
241         `Vcharacter_composition_table'.
242         (syms_of_mule_charset): Add new function `get-composite-char', new
243         symbol `->decomposition', `wide', `narrow', `compat', `noBreak',
244         `super' and `fraction'.
245         (vars_of_mule_charset): Setup `Vcharacter_composition_table'.
246
247 1999-11-12  MORIOKA Tomohiko  <tomo@urania.m17n.org>
248
249         * mule-charset.c (Fchar_attribute_alist): Check the argument is a
250         character; copy the return value.
251
252 1999-11-12  MORIOKA Tomohiko  <tomo@etl.go.jp>
253
254         * char-ucs.h (SPLIT_CHAR): Use `split_builtin_char'.
255
256         * mule-charset.c (range_charset_code_point): Must use make_int.
257         (split_builtin_char): New function.
258
259 1999-11-12  MORIOKA Tomohiko  <tomo@etl.go.jp>
260
261         * mule-charset.c (char_byte_table): Change name from
262         "char-code-table" to "char-byte-table".
263         (mark_char_code_table): New function.
264         (char_code_table_equal): New function.
265         (char_code_table_hash): New function.
266         (char_code_table_description): New constant.
267         (char_code_table): New type.
268         (make_char_code_table): New function.
269         (copy_char_code_table): New function.
270         (get_char_code_table): Modify for `char_code_table' type.
271         (put_char_code_table): Likewise.
272         (vars_of_mule_charset): Update `utf-2000-version' to 0.12
273         (Kashiwara).
274
275         * char-ucs.h (char_code_table): New type.
276         (XCHAR_CODE_TABLE): New macro.
277         (XSETCHAR_CODE_TABLE): New macro.
278         (CHAR_CODE_TABLE_P): New macro.
279         (GC_CHAR_CODE_TABLE_P): New macro.
280         (struct Lisp_Char_Code_Table): New structure.
281
282 1999-11-09  MORIOKA Tomohiko  <tomo@etl.go.jp>
283
284         * mule-charset.c (Fmake_charset): Setup byte_offset for
285         {94|96}^n-set.
286
287 1999-11-09  MORIOKA Tomohiko  <tomo@urania.m17n.org>
288
289         * mule-charset.c (Fdefine_char): Fix problem with non-UCS
290         character.
291
292 1999-11-09  MORIOKA Tomohiko  <tomo@etl.go.jp>
293
294         * char-ucs.h (SPLIT_CHAR): Don't make new cell if a charset slot
295         is found.
296
297 1999-11-09  MORIOKA Tomohiko  <tomo@etl.go.jp>
298
299         * mule-charset.c (Fget_char_attribute): If ATTRIBUTE is a name of
300         charset, it is regarded as a charset.
301         (put_char_attribute): New function in UTF-2000.
302         (Fput_char_attribute): If ATTRIBUTE is a charset or a name of
303         charset, mapping-table of the charset is modified.
304         (Fdefine_char): New function in UTF-2000.
305         (Fset_charset_mapping_table): Use `put_char_attribute' instead of
306         `Fput_char_attribute'.
307         (syms_of_mule_charset): Add new function `define-char' and new
308         symbol `ucs' in UTF-2000.
309         (vars_of_mule_charset): Update `utf-2000-version' to 0.11 (Shiki).
310
311 1999-10-29  MORIOKA Tomohiko  <tomo@etl.go.jp>
312
313         * mule-charset.c (Fcharset_name): Define `byte_offset' in
314         non-UTF-2000 configuration.
315
316 1999-10-29  MORIOKA Tomohiko  <tomo@etl.go.jp>
317
318         * text-coding.c (char_encode_shift_jis): Use `charset_code_point'
319         not to use `XCHARSET_ENCODING_TABLE (Vcharset_latin_jisx0201)'.
320
321         * mule-charset.c (mark_charset): `cs->encoding_table' has been
322         deleted.
323         (make_charset): Don't use `CHARSET_ENCODING_TABLE(cs)'.
324         (Fset_charset_mapping_table): Likewise.
325
326         * char-ucs.h (struct Lisp_Charset): Delete `encoding_table'.
327         (CHARSET_ENCODING_TABLE): Delete.
328         (XCHARSET_ENCODING_TABLE): Delete.
329         (charset_code_point): New interface.
330
331 1999-10-29  MORIOKA Tomohiko  <tomo@etl.go.jp>
332
333         * text-coding.c (char_encode_iso2022): Use `charset_code_point'
334         instead of `charset_get_byte1' and `charset_get_byte2'.
335
336         * mule-charset.c, char-ucs.h (charset_get_byte1): Deleted.
337         (charset_get_byte2): Deleted.
338
339 1999-10-28  MORIOKA Tomohiko  <tomo@etl.go.jp>
340
341         * char-ucs.h (SPLIT_CHAR): New inline function.
342         (breakup_char_1): Use `SPLIT_CHAR'.
343
344         * mule-charset.c (range_charset_code_point): New function.
345         (charset_code_point): New function.
346
347         * char-ucs.h (range_charset_code_point): New interface.
348         (breakup_char_1): Use `range_charset_code_point'.
349
350 1999-10-27  MORIOKA Tomohiko  <tomo@etl.go.jp>
351
352         * mule-charset.c (Fmake_charset): Delete unused local variable
353         `code_offset'.
354
355         * char-ucs.h (Vcharacter_attribute_table): New extern variable.
356         (breakup_char_1): Find a charset and code-point in
357         `Vcharacter_attribute_table'.
358
359 1999-10-27  MORIOKA Tomohiko  <tomo@etl.go.jp>
360
361         * mule-charset.c (vars_of_mule_charset): Update `utf-2000-version'
362         to 0.10 (Yao).
363
364 1999-10-25  MORIOKA Tomohiko  <tomo@etl.go.jp>
365
366         * mule-charset.c (Vcharacter_attribute_table): New variable.
367         (Fchar_attribute_alist): New function.
368         (Fget_char_attribute): New function.
369         (Fput_char_attribute): New function.
370         (Fset_charset_mapping_table): Setup `Vcharacter_attribute_table'
371         too.
372         (syms_of_mule_charset): Add new function `char-attribute-alist',
373         `get-char-attribute' and `put-char-attribute'.
374         (vars_of_mule_charset): Setup `Vcharacter_attribute_table'.
375
376 1999-10-19  MORIOKA Tomohiko  <tomo@etl.go.jp>
377
378         * mule-charset.c (Fmake_charset): Just use
379         `get_unallocated_leading_byte'.
380
381         * char-ucs.h (LEADING_BYTE_*): Use ISO-IR numbers for official
382         sets; don't use final-byte based number for private sets.
383
384 1999-10-12  MORIOKA Tomohiko  <tomo@etl.go.jp>
385
386         * doprnt.c (emacs_doprnt_1): Fix problem with %0XXd for a negative
387         integer.
388
389 1999-10-12  MORIOKA Tomohiko  <tomo@etl.go.jp>
390
391         * mule-charset.c (vars_of_mule_charset): Update `utf-2000-version'
392         to 0.9.
393
394 1999-10-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
395
396         * regex.c (compile_extended_range): Use `CHAR_CHARSET_ID' instead
397         of `CHAR_LEADING_BYTE' in UTF-2000.
398
399         * insdel.c (find_charsets_in_bufbyte_string): Use
400         `CHAR_CHARSET_ID' instead of `CHAR_LEADING_BYTE' in UTF-2000.
401         (find_charsets_in_emchar_string): Likewise.
402
403         * chartab.h (CHAR_TABLE_NON_ASCII_VALUE_UNSAFE): Use
404         `CHAR_CHARSET_ID' instead of `CHAR_LEADING_BYTE' in UTF-2000.
405
406         * char-ucs.h (CHAR_LEADING_BYTE): Deleted.
407         (CHAR_CHARSET_ID): New macro.
408
409 1999-10-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
410
411         * chartab.c (get_char_table): Don't use type `Charset_ID' for
412         charset-id - MIN_LEADING_BYTE.
413         (put_char_table): Likewise.
414
415 1999-10-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
416
417         * char-ucs.h (MIN_LEADING_BYTE): Changed to `-0x40'.
418         (NUM_LEADING_BYTES): Changed to (80 * 3 - MIN_LEADING_BYTE).
419         (CHARSET_LEADING_BYTE): Don't cast by `Bufbyte'.
420         (CHARSET_ID_OFFSET): New macro.
421         (LEADING_BYTE_CONTROL_1): Changed to (CHARSET_ID_OFFSET - 1).
422         (LEADING_BYTE_UCS_BMP): Changed to (CHARSET_ID_OFFSET - 2).
423         (LEADING_BYTE_LATIN_VISCII): Changed to (CHARSET_ID_OFFSET - 3).
424         (LEADING_BYTE_HIRAGANA_JISX0208): Changed to (CHARSET_ID_OFFSET -
425         4).
426         (LEADING_BYTE_KATAKANA_JISX0208): Changed to (CHARSET_ID_OFFSET -
427         5).
428         (MIN_LEADING_BYTE_PRIVATE): Changed to `MIN_LEADING_BYTE'.
429         (MAX_LEADING_BYTE_PRIVATE): Changed to (CHARSET_ID_OFFSET - 6).
430         (CHARSET_ID_OFFSET_94): Changed to (CHARSET_ID_OFFSET - '0').
431         (CHARSET_ID_OFFSET_96): Changed to (CHARSET_ID_OFFSET_94 + 80).
432         (CHARSET_ID_OFFSET_94x94): Changed to (CHARSET_ID_OFFSET_96 + 80).
433
434 1999-10-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
435
436         * mule-charset.c (next_allocated_leading_byte): New variable in
437         UTF-2000.
438         (next_allocated_1_byte_leading_byte): Don't define in UTF-2000.
439         (next_allocated_2_byte_leading_byte): Don't define in UTF-2000.
440         (get_unallocated_leading_byte): Simply use
441         `next_allocated_leading_byte' [ignore dimension] in UTF-2000.
442         (vars_of_mule_charset): Setup `next_allocated_leading_byte' in
443         UTF-2000.
444
445         * char-ucs.h (MIN_LEADING_BYTE_PRIVATE): New macro.
446         (MAX_LEADING_BYTE_PRIVATE): New macro.
447         (MIN_LEADING_BYTE_OFFICIAL_2): Deleted.
448         (MAX_LEADING_BYTE_OFFICIAL_2): Deleted.
449
450 1999-10-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
451
452         * mule-charset.c (Fmake_charset): Allocate final-byte based
453         charset-id for 94-set, 96-set and 94x94-set.
454
455 1999-10-11  MORIOKA Tomohiko  <tomo@etl.go.jp>
456
457         * mule-charset.c (char_byte_table_equal): Fill braces to avoid
458         ambiguous `else'.
459         (Fmake_charset): Likewise.
460         (complex_vars_of_mule_charset): Modify the font registry of
461         `ucs-bmp' not to match `Ethiopic-Unicode'.
462
463 1999-10-10  MORIOKA Tomohiko  <tomo@urania.m17n.org>
464
465         * mule-charset.c (complex_vars_of_mule_charset): Add font
466         registory of `ucs-bmp'.
467
468 1999-10-10  MORIOKA Tomohiko  <tomo@urania.m17n.org>
469
470         * text-coding.c (char_encode_iso2022): Ignore non-ISO-2022
471         coded-charsets in `default-coded-charset-priority-list' when
472         breaking up a character.
473
474         * mule-charset.c (Vcharset_latin_viscii): New variable.
475         (Qlatin_viscii): New variable.
476         (make_charset): Don't use `decoding_table'.
477         (Fmake_charset): Regard graphic = 2 as 256^n-set; setup
478         byte_offset.
479         (Fset_charset_mapping_table): New implementation.
480         (syms_of_mule_charset): Add new symbol `latin-viscii'.
481         (complex_vars_of_mule_charset): Set `graphic' attribute of charset
482         `ucs-bmp' and `latin_viscii' to 2; change font registry of charset
483         `latin-viscii-lower' to "MULEVISCII-LOWER"; change font registry
484         of charset `latin-viscii-upper' to "MULEVISCII-UPPER"; add new
485         charset `latin_viscii'.
486
487         * char-ucs.h (LEADING_BYTE_LATIN_VISCII): New macro.
488         (CHARSET_TYPE_94X94): Change to 1 from 2.
489         (CHARSET_TYPE_96): Change to 2 from 1.
490         (CHARSET_TYPE_128): New macro.
491         (CHARSET_TYPE_128X128): Change to 5 from 4.
492         (CHARSET_TYPE_256): New macro.
493         (CHARSET_TYPE_256X256): Change to 7 from 5.
494         (MAKE_CHAR): Use `XCHARSET_BYTE_OFFSET(charset)'.
495
496 1999-10-10  MORIOKA Tomohiko  <tomo@urania.m17n.org>
497
498         * text-coding.c (char_encode_shift_jis): Refer
499         `XCHARSET_ENCODING_TABLE(Vcharset_latin_jisx0201)' instead of
500         `XCHARSET_TO_BYTE1_TABLE(Vcharset_latin_jisx0201)'.
501
502         * mule-charset.c (mark_char_byte_table): New function in UTF-2000.
503         (char_byte_table_equal): New function in UTF-2000.
504         (char_byte_table_hash): New function in UTF-2000.
505         (char_byte_table_description): New constant in UTF-2000.
506         (char_byte_table): New type in UTF-2000.
507         (make_char_byte_table): New function in UTF-2000.
508         (copy_char_byte_table): New function in UTF-2000.
509         (make_char_code_table): New macro in UTF-2000.
510         (get_char_code_table): New function in UTF-2000.
511         (put_char_code_table): New function in UTF-2000.
512         (mark_charset): Mark `cs->encoding_table' in UTF-2000.
513         (charset_description): Add setting in UTF-2000.
514         (make_charset): Setup `CHARSET_ENCODING_TABLE(cs)' instead of
515         `CHARSET_TO_BYTE1_TABLE(cs)'.
516         (charset_get_byte1): Refer `XCHARSET_ENCODING_TABLE(charset)'
517         instead of `XCHARSET_TO_BYTE1_TABLE(charset)'.
518         (charset_get_byte2): Refer `XCHARSET_ENCODING_TABLE(charset)'
519         instead of `XCHARSET_TO_BYTE2_TABLE(charset)'.
520         (Fset_charset_mapping_table): Setup `CHARSET_ENCODING_TABLE(cs)'
521         instead of `CHARSET_TO_BYTE1_TABLE(cs)' and
522         `CHARSET_TO_BYTE2_TABLE(cs)'.
523
524         * char-ucs.h (char_byte_table): New type.
525         (XCHAR_BYTE_TABLE): New macro.
526         (XSETCHAR_BYTE_TABLE): New macro.
527         (CHAR_BYTE_TABLE_P): New macro.
528         (GC_CHAR_BYTE_TABLE_P): New macro.
529         (struct Lisp_Char_Byte_Table): New structure.
530         (get_char_code_table): New interface.
531         (Emchar_to_byte_table): Deleted.
532         (get_byte_from_character_table): Deleted.
533         (struct Lisp_Charset): Add `encoding_table'; delete
534         `to_byte1_table' and `to_byte2_table'.
535         (CHARSET_ENCODING_TABLE): New macro.
536         (CHARSET_TO_BYTE1_TABLE): Deleted.
537         (CHARSET_TO_BYTE2_TABLE): Deleted.
538         (XCHARSET_ENCODING_TABLE): New macro.
539         (XCHARSET_TO_BYTE1_TABLE): Deleted.
540         (XCHARSET_TO_BYTE2_TABLE): Deleted.
541
542 1999-10-07  MORIOKA Tomohiko  <tomo@etl.go.jp>
543
544         * mule-charset.c (syms_of_mule_charset): Delete charset alias
545         `vietnamese-viscii-*'.
546
547 1999-10-07  MORIOKA Tomohiko  <tomo@etl.go.jp>
548
549         * mule-charset.c (Qvietnamese_viscii_lower): New variable.
550         (Qvietnamese_viscii_upper): New variable.
551         (Fdefine_charset_alias): New function.
552         (syms_of_mule_charset): Add new function `define-charset-alias'.
553         (syms_of_mule_charset): Rename charset `vietnamese-viscii-*' to
554         `latin-viscii-*'; define `vietnamese-viscii-*' as aliases for
555         `latin-viscii-*'.
556
557 1999-10-04  MORIOKA Tomohiko  <tomo@etl.go.jp>
558
559         * char-ucs.h (MIN_CHAR_OBS_94x94): New macro.
560         (MAX_CHAR_OBS_94x94): New macro.
561         (breakup_char_1): Support obsolete XEmacs-UCS private code space
562         for 94x94 sets.
563
564         * mule-charset.c (put_byte_from_character_table): Change unit size
565         from 128 to 256.
566         (mark_charset): Don't mark `cs->decoding_table' if `UTF2000' is
567         not defined.
568         (Fmake_reverse_direction_charset): Modify dummy argument of
569         `make_charset' for non-UTF-2000 environment.
570
571 1999-10-03  MORIOKA Tomohiko  <tomo@urania.m17n.org>
572
573         * char-ucs.h (MAKE_CHAR): Allow nested decoding-table.
574
575         * mule-charset.c (destroy_byte_from_character_table): New macro.
576         (latin_jisx0201_to_ucs): Deleted.
577         (latin_iso8859_2_to_ucs): Deleted.
578         (latin_iso8859_3_to_ucs): Deleted.
579         (latin_iso8859_4_to_ucs): Deleted.
580         (latin_iso8859_9_to_ucs): Deleted.
581         (latin_viscii_lower_to_ucs): Deleted.
582         (latin_viscii_upper_to_ucs): Deleted.
583         (mark_charset): Mark `cs->decoding_table'.
584         (Fcharset_mapping_table): Fix DOC-string.
585         (Fset_charset_mapping_table): New function.
586         (syms_of_mule_charset): Add nwe function
587         `set-charset-mapping-table'.
588         (complex_vars_of_mule_charset): Don't setup and use
589         `latin_*_to_ucs'.
590
591 1999-10-01  MORIOKA Tomohiko  <tomo@urania.m17n.org>
592
593         * char-ucs.h (MAKE_CHAR): Check the result for range-represented
594         charset.
595
596 1999-09-30  MORIOKA Tomohiko  <tomo@urania.m17n.org>
597
598         * mule-charset.c (Vcharset_hiragana_jisx0208): New variable.
599         (Vcharset_katakana_jisx0208): New variable.
600         (Qhiragana_jisx0208): New variable.
601         (Qkatakana_jisx0208): New variable.
602         (make_charset): Add new argument `byte_offset'.
603         (charset_get_byte1): Modify for new coded-charset definition; use
604         `XCHARSET_UCS_MIN', `XCHARSET_UCS_MAX', `XCHARSET_CODE_OFFSET' and
605         `XCHARSET_BYTE_OFFSET'.
606         (Fmake_charset): Modify for `make_charset'.
607         (Fmake_reverse_direction_charset): Likewise.
608         (syms_of_mule_charset): Add new symbols `hiragana-jisx0208' and
609         `katakana-jisx0208'.
610         (complex_vars_of_mule_charset): Modify for `make_charset'; quote
611         `.'  in font registry of charset `katakana-jisx0201',
612         `latin-jisx0201', `vietnamese-viscii-lower' and
613         `vietnamese-viscii-upper'; modify DOC-string of charset
614         `japanese-jisx0208-1978' and `japanese-jisx0208'; modify font
615         registry of charset `japanese-jisx0208' not to use font for JIS
616         X0208:1990; add new charset `hiragana-jisx0208' and
617         `katakana-jisx0208'.
618
619         * char-ucs.h (LEADING_BYTE_HIRAGANA_JISX0208): New macro.
620         (LEADING_BYTE_KATAKANA_JISX0208): New macro.
621         (struct Lisp_Charset): Add `byte_offset'.
622         (CHARSET_BYTE_OFFSET): New macro.
623         (XCHARSET_UCS_MIN): New macro.
624         (XCHARSET_UCS_MAX): New macro.
625         (XCHARSET_CODE_OFFSET): New macro.
626         (XCHARSET_BYTE_OFFSET): New macro.
627         (MIN_CHAR_HIRAGANA): New macro.
628         (MAX_CHAR_HIRAGANA): New macro.
629         (MIN_CHAR_KATAKANA): New macro.
630         (MAX_CHAR_KATAKANA): New macro.
631         (MAKE_CHAR): Modify for new coded-charset definition; use
632         `XCHARSET_UCS_MIN', `XCHARSET_UCS_MAX', `XCHARSET_CODE_OFFSET' and
633         `XCHARSET_BYTE_OFFSET'.
634
635 1999-09-27  MORIOKA Tomohiko  <tomo@etl.go.jp>
636
637         * mule-charset.c (CHAR96): Deleted.
638         (latin_jisx0201_to_ucs): Type is changed from array of <Emchar> to
639         <Lisp_Object>.
640         (latin_iso8859_2_to_ucs): Likewise.
641         (latin_iso8859_3_to_ucs): Likewise.
642         (latin_iso8859_4_to_ucs): Likewise.
643         (latin_iso8859_9_to_ucs): Likewise.
644         (latin_viscii_lower_to_ucs): Likewise.
645         (latin_viscii_upper_to_ucs): Likewise.
646         (latin_tcvn5712_to_ucs): Commented out.
647         (make_charset): Change type of argument `decoding_table' from
648         <Emchar*> to <Lisp_Object> [vector of characters].
649         (Fmake_charset): Modify for `make_charset'.
650         (Fmake_reverse_direction_charset): Likewise.
651         (Fcharset_mapping_table): New function in UTF-2000.
652         (syms_of_mule_charset): Setup `Fcharset_mapping_table' in
653         UTF-2000.
654         (complex_vars_of_mule_charset): Modify for type change of
655         `*_to_ucs'; modify for `make_charset'.
656
657         * char-ucs.h (struct Lisp_Charset): Change type of
658         `decoding_table' from <Emchar*> to <Lisp_Object>.
659         (MAKE_CHAR): Modify for new specification of `decoding_table'.
660
661 1999-09-23  MORIOKA Tomohiko  <tomo@etl.go.jp>
662
663         * mule-charset.c (Fmake_reverse_direction_charset): Fix compile
664         error with non-UTF-2000-Mule.
665
666 1999-09-21  MORIOKA Tomohiko  <tomo@etl.go.jp>
667
668         * mule-charset.c (Vcharset_chinese_cns11643_3): Deleted [defined
669         in lisp again].
670         (Vcharset_chinese_cns11643_4): Likewise.
671         (Vcharset_chinese_cns11643_5): Likewise.
672         (Vcharset_chinese_cns11643_6): Likewise.
673         (Vcharset_chinese_cns11643_7): Likewise.
674         (Qchinese_cns11643_3): Likewise.
675         (Qchinese_cns11643_4): Likewise.
676         (Qchinese_cns11643_5): Likewise.
677         (Qchinese_cns11643_6): Likewise.
678         (Qchinese_cns11643_7): Likewise.
679         (syms_of_mule_charset): Move definitions for `chinese-cns11643-3',
680         `chinese-cns11643-4', `chinese-cns11643-5', `chinese-cns11643-6'
681         and `chinese-cns11643-7' to lisp/mule/chinese.el.
682         (complex_vars_of_mule_charset): Likewise.
683
684 1999-09-18  MORIOKA Tomohiko  <tomo@etl.go.jp>
685
686         * mule-charset.c (charset_get_byte1): Fix bug about 94- and
687         96-set.
688         (Fmake_reverse_direction_charset): Inherit CHARSET_DECODING_TABLE,
689         CHARSET_UCS_MIN, CHARSET_UCS_MAX and CHARSET_CODE_OFFSET.
690
691 1999-09-17  MORIOKA Tomohiko  <tomo@etl.go.jp>
692
693         * char-ucs.h (MIN_CHAR_HALFWIDTH_KATAKANA): Changed to 0xFF61 from
694         0xFF60.
695         (MAKE_CHAR): Change offset for katakana-jisx0201 to 33 from 0x20.
696         (breakup_char_1): Likewise.
697
698         * text-coding.c (char_encode_iso2022): Keep designated charsets if
699         one of them includes the specified character.
700
701 1999-09-14  MORIOKA Tomohiko  <tomo@etl.go.jp>
702
703         * mule-charset.c: Update `utf-2000-version' to 0.8 (Kami).
704
705 1999-09-14  MORIOKA Tomohiko  <tomo@etl.go.jp>
706
707         * char-ucs.h (MAKE_CHAR): Fix problem in 2-dimension charset.
708
709 1999-09-14  MORIOKA Tomohiko  <tomo@etl.go.jp>
710
711         * mule-charset.c (latin_iso8859_2_to_ucs NULL): Add pseudo
712         definition for non-UTF-2000 Mule.
713         (latin_iso8859_3_to_ucs): Likewise.
714         (latin_iso8859_4_to_ucs): Likewise.
715         (latin_iso8859_9_to_ucs): Likewise.
716         (latin_jisx0201_to_ucs): Likewise.
717         (MIN_CHAR_THAI): Likewise.
718         (MAX_CHAR_THAI): Likewise.
719         (MIN_CHAR_GREEK): Likewise.
720         (MAX_CHAR_GREEK): Likewise.
721         (MIN_CHAR_HEBREW): Likewise.
722         (MAX_CHAR_HEBREW): Likewise.
723         (MIN_CHAR_HALFWIDTH_KATAKANA): Likewise.
724         (MAX_CHAR_HALFWIDTH_KATAKANA): Likewise.
725         (MIN_CHAR_CYRILLIC): Likewise.
726         (MAX_CHAR_CYRILLIC): Likewise.
727
728 1999-09-14  MORIOKA Tomohiko  <tomo@etl.go.jp>
729
730         * char-ucs.h (breakup_char_1): Use
731         `Vdefault_coded_charset_priority_list' for hebrew-iso8859-8,
732         thai-tis620 and katakana-jisx0201 area.
733
734 1999-09-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
735
736         * char-ucs.h (breakup_char_1): Use
737         `Vdefault_coded_charset_priority_list' for cyrillic-iso8859-5
738         area.
739
740         * text-coding.c (reset_encoding_stream): Fixed.
741         (char_encode_ucs4): Delete `& 255'.
742
743         * char-ucs.h (breakup_char_1): Use
744         `Vdefault_coded_charset_priority_list' for greek-iso8859-7 area.
745
746 1999-09-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
747
748         * file-coding.c (Fmake_coding_system): Don't set up
749         `codesys->fixed.size'.
750         (encode_coding_no_conversion): Don't refer
751         `str->codesys->fixed.size'.
752
753 1999-09-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
754
755         * mule-charset.c, char-ucs.h (latin_a_char_to_charset): Deleted.
756         (latin_a_char_to_byte1): Deleted.
757         (latin_a_char_to_byte2): Deleted.
758
759 1999-09-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
760
761         * mule-charset.c (make_charset): Add new argument `ucs_min',
762         `ucs_max' and `code_offset'.
763         (charset_get_byte1): New implementation [delete specific charset
764         depended implementations].
765         (Fmake_charset): Modify for `make_charset'.
766         (Fmake_reverse_direction_charset): Likewise.
767         (complex_vars_of_mule_charset): Likewise.
768
769         * char-ucs.h (struct Lisp_Charset): Add `ucs_min', `ucs_max' and
770         `code_offset'.
771         (CHARSET_UCS_MIN): New macro.
772         (CHARSET_UCS_MAX): New macro.
773         (CHARSET_CODE_OFFSET): New macro.
774         (MAKE_CHAR): Delete charset depended definitions [except
775         katakana-jisx0201].
776
777 1999-09-13  MORIOKA Tomohiko  <tomo@etl.go.jp>
778
779         * char-ucs.h (breakup_char_1): Use
780         `Vdefault_coded_charset_priority_list' for C0-Controls,
781         Basic-Latin, C1-Controls and Latin-1-Supplement area.
782
783 1999-09-13  MORIOKA Tomohiko  <tomo@urania.m17n.org>
784
785         * char-ucs.h (charset_get_byte1): New function.
786         (XCHARSET_GET_BYTE1): Deleted.
787         (charset_get_byte2): New function.
788         (XCHARSET_GET_BYTE2): Deleted.
789         (Vdefault_coded_charset_priority_list): New external variable.
790         (breakup_char_1): Use `charset_get_byte1', `charset_get_byte2' and
791         `Vdefault_preferred_coded_charset_list'.
792
793         * mule-charset.c (charset_get_byte1): New function.
794         (charset_get_byte2): New function.
795         (Vdefault_coded_charset_priority_list): New variable.
796         (vars_of_mule_charset): Add new variable
797         `default-coded-charset-priority-list'.
798
799 1999-09-12  MORIOKA Tomohiko  <tomo@urania.m17n.org>
800
801         * char-ucs.h (XCHARSET_GET_BYTE1): New inline function.
802         (XCHARSET_GET_BYTE2): New inline function.
803         (breakup_char_1): Use `XCHARSET_GET_BYTE1' and
804         `XCHARSET_GET_BYTE2'.
805
806 1999-09-12  MORIOKA Tomohiko  <tomo@urania.m17n.org>
807
808         * mule-charset.c (make_charset): Initialize
809         `CHARSET_TO_BYTE1_TABLE(cs)' and `CHARSET_TO_BYTE2_TABLE(cs)' by
810         NULL if table is not defined.
811
812 1999-09-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
813
814         * text-coding.c (char_encode_shift_jis): Use
815         `XCHARSET_TO_BYTE1_TABLE' for `Vcharset_latin_jisx0201' instead of
816         `ucs_to_latin_jisx0201'.
817
818         * mule-charset.c (ucs_to_latin_jisx0201): Deleted.
819         (ucs_to_latin_iso8859_2): Deleted.
820         (ucs_to_latin_iso8859_3): Deleted.
821         (ucs_to_latin_iso8859_4): Deleted.
822         (ucs_to_latin_iso8859_9): Deleted.
823         (ucs_to_latin_viscii_lower): Deleted.
824         (ucs_to_latin_viscii_upper): Deleted.
825         (ucs_to_latin_tcvn5712): Deleted.
826         (make_charset): Add new argument `decoding_table'; set up
827         `CHARSET_DECODING_TABLE(cs)' in UTF-2000; set up
828         `CHARSET_TO_BYTE1_TABLE(cs)' for 94-set and 96-set if
829         `decoding_table' is defined in UTF-2000.
830         (Fmake_charset): Modify for `make_charset'.
831         (Fmake_reverse_direction_charset): Likewise.
832         (complex_vars_of_mule_charset): Likewise; delete `GENERATE_94_SET'
833         and `GENERATE_96_SET'.
834
835         * char-ucs.h (latin_jisx0201_to_ucs): Deleted.
836         (ucs_to_latin_jisx0201): Deleted.
837         (latin_iso8859_2_to_ucs): Deleted.
838         (ucs_to_latin_iso8859_2): Deleted.
839         (latin_iso8859_3_to_ucs): Deleted.
840         (ucs_to_latin_iso8859_3): Deleted.
841         (latin_iso8859_4_to_ucs): Deleted.
842         (ucs_to_latin_iso8859_4): Deleted.
843         (latin_iso8859_9_to_ucs): Deleted.
844         (ucs_to_latin_iso8859_9): Deleted.
845         (latin_viscii_lower_to_ucs): Deleted.
846         (ucs_to_latin_viscii_lower): Deleted.
847         (latin_viscii_upper_to_ucs): Deleted.
848         (ucs_to_latin_viscii_upper): Deleted.
849         (struct Lisp_Charset): Renamed `encoding_table' to
850         `to_byte1_table'; add `to_byte2_table'.
851         (CHARSET_DECODING_TABLE): New macro.
852         (CHARSET_TO_BYTE1_TABLE): New macro.
853         (CHARSET_TO_BYTE2_TABLE): New macro.
854         (XCHARSET_DECODING_TABLE): New macro.
855         (XCHARSET_TO_BYTE1_TABLE): New macro.
856         (XCHARSET_TO_BYTE2_TABLE): New macro.
857         (MAKE_CHAR): Use `XCHARSET_DECODING_TABLE'; don't use `*_to_ucs'
858         tables.
859         (breakup_char_1): Use `XCHARSET_TO_BYTE1_TABLE' if it is defined;
860         don't use `ucs_to_*' tables.
861
862 1999-09-11  MORIOKA Tomohiko  <tomo@urania.m17n.org>
863
864         * text-coding.c (Fmake_coding_system): Don't set up
865         `codesys->fixed.size'.
866         (encode_coding_no_conversion): Use `if' instead of `switch'.
867
868         * file-coding.h (struct Lisp_Coding_System): Delete `fixed.size'.
869
870 1999-09-11  MORIOKA Tomohiko  <tomo@etl.go.jp>
871
872         * mule-charset.c (make_charset): Delete argument `rep_bytes'.
873         (Fmake_charset): Modify for `make_charset'.
874         (Fmake_reverse_direction_charset): Likewise.
875         (complex_vars_of_mule_charset): Likewise.
876
877 1999-09-11  MORIOKA Tomohiko  <tomo@etl.go.jp>
878
879         * text-coding.c (char_encode_shift_jis): Use table
880         `ucs_to_latin_jisx0201' and BREAKUP_CHAR.
881
882 1999-09-11  MORIOKA Tomohiko  <tomo@etl.go.jp>
883
884         * text-coding.c (text_encode_generic): Use `if' instead of
885         `switch'.
886         (decode_coding_sjis): Use `MAKE_CHAR' and `DECODE_ADD_UCS_CHAR' to
887         decode JIS-Latin.
888
889 1999-09-10  MORIOKA Tomohiko  <tomo@etl.go.jp>
890
891         * text-coding.c (encode_coding_sjis): Deleted.
892         (char_encode_shift_jis): New function.
893         (char_finish_shift_jis): New function.
894         (reset_encoding_stream): Set up `encode_char' and `finish' for
895         `CODESYS_UCS4' and `CODESYS_SHIFT_JIS'.
896         (mule_encode): Use generic encoder for `CODESYS_SHIFT_JIS'.
897         (char_encode_utf8): Treat `eol_type'.
898
899 1999-09-10  MORIOKA Tomohiko  <tomo@etl.go.jp>
900
901         * file-coding.c (decode_coding_iso2022): Use
902         `DECODE_ADD_UCS_CHAR'; don't use `XCHARSET_REP_BYTES'.
903
904 1999-09-10  MORIOKA Tomohiko  <tomo@etl.go.jp>
905
906         * mule-charset.c (vars_of_mule_charset): Update `utf-2000-version'
907         to 0.7 (Hirano).
908
909 1999-09-10  MORIOKA Tomohiko  <tomo@etl.go.jp>
910
911         * char-lb.h (CHAR_COLUMNS): New macro.
912
913 1999-09-09  MORIOKA Tomohiko  <tomo@etl.go.jp>
914
915         * text-coding.c (char_encode_ucs4): New function.
916         (char_finish_ucs4): New function.
917         (encode_coding_ucs4): Deleted.
918         (mule_encode): Use generic encoder for `CODESYS_UCS4'.
919         (text_encode_generic): Delete local variable `charset' and `half'.
920         (ucs_to_mule_table): Deleted.
921         (mule_to_ucs_table): Deleted.
922         (Fset_ucs_char): Deleted.
923         (ucs_to_char): Deleted.
924         (Fucs_char): Deleted.
925         (Fset_char_ucs): Deleted.
926         (Fchar_ucs): Deleted.
927         (decode_ucs4): Deleted.
928         (mule_char_to_ucs4): Deleted.
929         (encode_ucs4): Deleted.
930         (decode_coding_ucs4): Use `DECODE_ADD_UCS_CHAR'.
931         (decode_coding_utf8): Likewise.
932         (decode_coding_iso2022): Likewise; don't use `XCHARSET_REP_BYTES'.
933         (char_encode_iso2022): Fixed.
934         (syms_of_file_coding): Delete `Fset_ucs_char', `Fucs_char',
935         `Fset_char_ucs' and `Fchar_ucs'.
936         (complex_vars_of_file_coding): Don't initialize
937         `ucs_to_mule_table'.
938
939         * objects-tty.c (tty_initialize_font_instance): Don't use
940         `XCHARSET_COLUMNS'.
941
942         * mule-charset.c (make_charset): Don't set up CHARSET_REP_BYTES in
943         UTF-2000.
944
945         * redisplay-tty.c (tty_output_display_block): Use `CHAR_COLUMNS'
946         instead of `XCHARSET_COLUMNS' and `CHAR_CHARSET'.
947
948         * insdel.c (bufbyte_string_displayed_columns): Use `CHAR_COLUMNS'
949         instead of `XCHARSET_COLUMNS' and `CHAR_CHARSET'.
950         (emchar_string_displayed_columns): Likewise.
951
952         * indent.c (column_at_point): Use `CHAR_COLUMNS' instead of
953         `XCHARSET_COLUMNS' and `CHAR_CHARSET'.
954         (string_column_at_point): Likewise.
955         (Fmove_to_column): Likewise.
956
957         * char-ucs.h (struct Lisp_Charset): Delete `rep_bytes'; add
958         `encoding_table' and `decoding_table'.
959         (CHARSET_REP_BYTES): Deleted.
960         (XCHARSET_REP_BYTES): Deleted.
961         (XCHARSET_COLUMNS): Deleted.
962         (CHAR_COLUMNS): New macro.
963         (lookup_composite_char): Deleted unconditionally.
964         (composite_char_string): Likewise.
965
966 1999-09-09  MORIOKA Tomohiko  <tomo@etl.go.jp>
967
968         * char-ucs.h (Emchar_to_byte_table): New type.
969         (get_byte_from_character_table): New function interface.
970         (Vcharset_latin_jisx0201): New variable.
971         (latin_jisx0201_to_ucs): New variable.
972         (ucs_to_latin_jisx0201): New variable.
973         (Vcharset_latin_iso8859_2): New variable.
974         (latin_iso8859_2_to_ucs): New variable.
975         (ucs_to_latin_iso8859_2): New variable.
976         (Vcharset_latin_iso8859_3): New variable.
977         (latin_iso8859_3_to_ucs): New variable.
978         (ucs_to_latin_iso8859_3): New variable.
979         (Vcharset_latin_iso8859_4): New variable.
980         (latin_iso8859_4_to_ucs): New variable.
981         (ucs_to_latin_iso8859_4): New variable.
982         (Vcharset_latin_iso8859_9): New variable.
983         (latin_iso8859_9_to_ucs): New variable.
984         (ucs_to_latin_iso8859_9): New variable.
985         (Vcharset_latin_viscii_lower): New variable.
986         (latin_viscii_lower_to_ucs): New variable.
987         (ucs_to_latin_viscii_lower): New variable.
988         (Vcharset_latin_viscii_upper): New variable.
989         (latin_viscii_upper_to_ucs): New variable.
990         (ucs_to_latin_viscii_upper): New variable.
991         (CHARSET_ID_OFFSET_94): Changed from 0x60 to 0x55.
992         (LEADING_BYTE_LATIN_VISCII_LOWER): New macro.
993         (LEADING_BYTE_LATIN_VISCII_UPPER): New macro.
994         (MAKE_CHAR): Map `latin-iso8859-2', `latin-iso8859-3',
995         `latin-iso8859-4', `latin-iso8859-9', `latin-jisx0201',
996         `vietnamese-viscii-lower' and `vietnamese-viscii-upper' to BMP.
997         (breakup_char_1): Use `ucs_to_latin_iso8859_2',
998         `ucs_to_latin_iso8859_3', `ucs_to_latin_iso8859_4',
999         `ucs_to_latin_iso8859_9', `ucs_to_latin_viscii_lower',
1000         `ucs_to_latin_viscii_upper' and `ucs_to_latin_jisx0201' tables.
1001
1002         * mule-charset.c (Vcharset_latin_viscii_lower): New variable.
1003         (Vcharset_latin_viscii_upper): New variable.
1004         (make_byte_from_character_table): New function.
1005         (put_byte_from_character_table): New function.
1006         (get_byte_from_character_table): New function.
1007         (CHAR96): New macro.
1008         (ucs_to_latin_jisx0201): New variable.
1009         (latin_jisx0201_to_ucs): New variable.
1010         (ucs_to_latin_iso8859_2): New variable.
1011         (latin_iso8859_2_to_ucs): New variable.
1012         (ucs_to_latin_iso8859_3): New variable.
1013         (latin_iso8859_3_to_ucs): New variable.
1014         (ucs_to_latin_iso8859_4): New variable.
1015         (latin_iso8859_4_to_ucs): New variable.
1016         (ucs_to_latin_iso8859_9): New variable.
1017         (latin_iso8859_9_to_ucs): New variable.
1018         (ucs_to_latin_viscii_lower): New variable.
1019         (latin_viscii_lower_to_ucs): New variable.
1020         (ucs_to_latin_viscii_upper): New variable.
1021         (latin_viscii_upper_to_ucs): New variable.
1022         (ucs_to_latin_tcvn5712): New variable.
1023         (latin_tcvn5712_to_ucs): New variable.
1024         (Qlatin_viscii_lower): New variable.
1025         (Qlatin_viscii_upper): New variable.
1026         (syms_of_mule_charset): Set up new symbol
1027         `vietnamese-viscii-lower' and `vietnamese-viscii-upper'.
1028         (complex_vars_of_mule_charset): Set up new charset
1029         `vietnamese-viscii-lower' and `vietnamese-viscii-upper'; new macro
1030         `GENERATE_94_SET' and `GENERATE_96_SET'; use them to generate
1031         `ucs_to_<CHARSET>' tables.
1032
1033 1999-09-08  MORIOKA Tomohiko  <tomo@etl.go.jp>
1034
1035         * text-coding.c: New file.
1036
1037 1999-09-07  MORIOKA Tomohiko  <tomo@etl.go.jp>
1038
1039         * mule-charset.c (Fmake_char): Fix problem of 256-set.
1040
1041         * char-ucs.h (Vcharset_ucs_bmp): New variable.
1042         (MAKE_CHAR): Modify for `ucs-bmp'.
1043         (breakup_char_1): Return `ucs-bmp' and code point of BMP for
1044         non-MULE characters of BMP.
1045
1046 1999-09-06  MORIOKA Tomohiko  <tomo@etl.go.jp>
1047
1048         * mule-charset.c (vars_of_mule_charset):
1049         Update `utf-2000-version' to 0.6.
1050
1051 1999-09-05  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1052
1053         * lstream.h:
1054         - Include multibyte.h instead of character.h for `BYTE_ASCII_P'.
1055         - Include character.h for `CHAR_ASCII_P'.
1056
1057         * mb-multibyte.h (CHAR_MULTIBYTE_P): Moved from mule-charset.h.
1058
1059         * mule-charset.h (CHAR_MULTIBYTE_P): Moved to mb-multibyte.h.
1060         (CHAR_ASCII_P): Don't use `CHAR_MULTIBYTE_P'.
1061
1062         * mb-multibyte.h (BYTE_ASCII_P): Moved from char-ucs.h.
1063         (BYTE_C0_P): Likewise.
1064         (BYTE_C1_P): Likewise.
1065         (Lstream_get_emchar_1): Likewise.
1066         (Lstream_fput_emchar): Likewise.
1067         (Lstream_funget_emchar): Likewise.
1068         (copy_internal_to_external): Likewise.
1069         (copy_external_to_internal): Likewise.
1070
1071         * char-ucs.h (BYTE_ASCII_P): Moved to mb-multibyte.h.
1072         (BYTE_C0_P): Likewise.
1073         (BYTE_C1_P): Likewise.
1074         (Lstream_get_emchar_1): Likewise.
1075         (Lstream_fput_emchar): Likewise.
1076         (Lstream_funget_emchar): Likewise.
1077         (copy_internal_to_external): Likewise.
1078         (copy_external_to_internal): Likewise.
1079
1080         * mb-1byte.h (BYTE_ASCII_P): Moved from buffer.h.
1081         (REP_BYTES_BY_FIRST_BYTE): Likewise.
1082
1083         * buffer.h (REP_BYTES_BY_FIRST_BYTE): Moved to mb-1byte.h.
1084         (BYTE_ASCII_P): Moved to mb-1byte.h.
1085
1086 1999-09-04  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1087
1088         * mb-utf-8.h, mb-lb.h: Include mb-multibyte.h.
1089
1090         * multibyte.h: Include mb-1byte.h in unibyte-XEmacs.
1091         (MAX_EMCHAR_LEN): Moved to mb-1byte.h.
1092         (VALID_CHARPTR_P): Moved to mb-*byte.h.
1093         (VALIDATE_CHARPTR_BACKWARD): Likewise.
1094         (VALIDATE_CHARPTR_FORWARD): Likewise.
1095         (simple_charptr_emchar): Moved to mb-multibyte.h.
1096         (simple_set_charptr_emchar): Likewise.
1097         (simple_charptr_copy_char): Likewise.
1098         (non_ascii_charptr_emchar): Likewise.
1099         (non_ascii_set_charptr_emchar): Likewise.
1100         (non_ascii_charptr_copy_char): Likewise.
1101         (charptr_emchar): Moved to mb-*byte.h.
1102         (set_charptr_emchar): Likewise.
1103         (charptr_copy_char): Likewise.
1104
1105         * mb-1byte.h, mb-multibyte.h: New files.
1106
1107 1999-09-03  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1108
1109         * mb-utf-8.h (MULTIBYTE): New macro.
1110         (MAX_EMCHAR_LEN): Moved from buffer.h.
1111         (REP_BYTES_BY_FIRST_BYTE): Moved from char-ucs.h.
1112
1113         * char-ucs.h (REP_BYTES_BY_FIRST_BYTE): Moved to mb-utf-8.h.
1114
1115         * mb-lb.h, multibyte.h: New files.
1116
1117         * char-1byte.h (Charset_ID): Moved from buffer.h.
1118         (MIN_LEADING_BYTE): Likewise.
1119         (LEADING_BYTE_ASCII): Likewise.
1120         (NUM_LEADING_BYTES): Likewise.
1121         (CHARSETP): Likewise.
1122         (CHARSET_BY_LEADING_BYTE): Likewise.
1123         (XCHARSET_LEADING_BYTE): Likewise.
1124         (XCHARSET_GRAPHIC): Likewise.
1125         (XCHARSET_COLUMNS): Likewise.
1126         (XCHARSET_DIMENSION): Likewise.
1127         (CHAR_CHARSET): Likewise.
1128         (CHAR_LEADING_BYTE): Likewise.
1129         (BREAKUP_CHAR): Likewise.
1130         (Vcharset_ascii): Likewise.
1131
1132         * buffer.h: Include multibyte.h unconditionally.
1133         (VALID_CHARPTR_P): Moved to multibyte.h.
1134         (ASSERT_VALID_CHARPTR): Likewise.
1135         (REAL_INC_CHARPTR): Likewise.
1136         (REAL_INC_CHARBYTIND): Likewise.
1137         (REAL_DEC_CHARPTR): Likewise.
1138         (INC_CHARPTR): Likewise.
1139         (INC_CHARBYTIND): Likewise.
1140         (DEC_CHARPTR): Likewise.
1141         (VALIDATE_CHARPTR_BACKWARD): Likewise.
1142         (VALIDATE_CHARPTR_FORWARD): Likewise.
1143         (charptr_n_addr): Likewise.
1144         (MAX_EMCHAR_LEN): Moved to mb-*.h.
1145         (simple_charptr_emchar): Moved to multibyte.h.
1146         (simple_set_charptr_emchar): Likewise.
1147         (simple_charptr_copy_char): Likewise.
1148         (non_ascii_charptr_emchar): Likewise.
1149         (non_ascii_set_charptr_emchar): Likewise.
1150         (non_ascii_charptr_copy_char): Likewise.
1151         (charptr_emchar): Likewise.
1152         (set_charptr_emchar): Likewise.
1153         (charptr_copy_char): Likewise.
1154         (charptr_emchar_n): Likewise.
1155         (Charset_ID): Moved to char-1byte.h.
1156         (Vcharset_ascii): Likewise.
1157         (CHAR_CHARSET): Likewise.
1158         (CHAR_LEADING_BYTE): Likewise.
1159         (LEADING_BYTE_ASCII): Likewise.
1160         (NUM_LEADING_BYTES): Likewise.
1161         (MIN_LEADING_BYTE): Likewise.
1162         (CHARSETP): Likewise.
1163         (CHARSET_BY_LEADING_BYTE): Likewise.
1164         (XCHARSET_LEADING_BYTE): Likewise.
1165         (XCHARSET_GRAPHIC): Likewise.
1166         (XCHARSET_COLUMNS): Likewise.
1167         (XCHARSET_DIMENSION): Likewise.
1168         (BREAKUP_CHAR): Likewise.
1169
1170 1999-09-02  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1171
1172         * character.h: Add document about interface for characters.
1173
1174         * char-ucs.h (CHAR_ASCII_P): Modify name of argument.
1175         (MAKE_CHAR): Delete comment about
1176         `FIELD2_TO_OFFICIAL_LEADING_BYTE' and
1177         `FIELD2_TO_PRIVATE_LEADING_BYTE'.
1178         (BREAKUP_CHAR): Modify name of arguments.
1179         (CHAR_CHARSET): Modify name of argument.
1180
1181         * buffer.h: Delete document about Emchar accessors.
1182
1183 1999-09-02  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1184
1185         * character.h (CHAR_INTP): Moved from buffer.h
1186         (CHAR_OR_CHAR_INTP): Likewise.
1187         (XCHAR_OR_CHAR_INT): Likewise.
1188         (CHECK_CHAR_COERCE_INT): Likewise.
1189
1190         * buffer.h (CHAR_INTP): Moved to character.h
1191         (CHAR_OR_CHAR_INTP): Likewise.
1192         (XCHAR_OR_CHAR_INT): Likewise.
1193         (CHECK_CHAR_COERCE_INT): Likewise.
1194
1195 1999-09-02  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1196
1197         * character.h:
1198         - Move definitions about UCS-2000 (UCS-4) to char-ucs.h.
1199         - Include char-1byte.h, char-lb.h or char-ucs.h.
1200
1201         * mb-utf-8.h (CHAR_ASCII_P): Moved to char-ucs.h.
1202
1203         * buffer.h: Include character unconditionally.
1204         (valid_char_p): Moved to char-*.h.
1205         (non_ascii_valid_char_p): Moved to char-lb.h.
1206
1207         * char-1byte.h, char-lb.h, char-ucs.h: New files.
1208
1209 1999-09-02  MORIOKA Tomohiko  <tomo@urania.m17n.org>
1210
1211         * mule-ccl.c (ccl_driver): Don't define `CCL_WriteMultibyteChar2'
1212         in UTF-2000 because it is not ported yet and not to use
1213         `FIELD2_TO_OFFICIAL_LEADING_BYTE', `MIN_LEADING_BYTE_OFFICIAL_2',
1214         `FIELD1_TO_OFFICIAL_LEADING_BYTE' and
1215         `FIELD1_TO_PRIVATE_LEADING_BYTE'.
1216
1217         * mb-utf-8.h (CHAR_MULTIBYTE_P): Moved from character.h.
1218         (CHAR_ASCII_P): Moved from character.h.
1219
1220         * character.h (CHAR_MULTIBYTE_P): Moved to mb-utf-8.h.
1221         (CHAR_ASCII_P): Likewise.
1222         (CHAR_FIELD1_MASK): Deleted.
1223         (CHAR_FIELD2_MASK): Deleted.
1224         (CHAR_FIELD3_MASK): Deleted.
1225         (MAX_CHAR_BASIC_LATIN): New macro.
1226         (CHAR_FIELD1): Deleted.
1227         (CHAR_FIELD2_INTERNAL): Deleted.
1228         (CHAR_FIELD3_INTERNAL): Deleted.
1229         (FIELD1_TO_PRIVATE_LEADING_BYTE): Deleted.
1230         (FIELD1_TO_OFFICIAL_LEADING_BYTE): Deleted.
1231         (FIELD2_TO_PRIVATE_LEADING_BYTE): Deleted.
1232         (FIELD2_TO_OFFICIAL_LEADING_BYTE): Deleted.
1233         (MIN_CHAR_FIELD1_OFFICIAL): Deleted.
1234         (MAX_CHAR_FIELD1_OFFICIAL): Deleted.
1235         (MIN_CHAR_FIELD2_PRIVATE): Deleted.
1236         (MAX_CHAR_FIELD2_PRIVATE): Deleted.
1237         (MIN_CHAR_FIELD1_PRIVATE): Deleted.
1238         (MAX_CHAR_FIELD1_PRIVATE): Deleted.
1239         (MULE_CHAR_PRIVATE_OFFSET): Deleted.
1240         (MIN_CHAR_PRIVATE_TYPE9N): Deleted.
1241         (MAX_CHAR_PRIVATE_TYPE9N): Deleted.
1242         (MIN_CHAR_PRIVATE_TYPE9NX9N): Deleted.
1243         (MIN_CHAR_OFFICIAL_TYPE9NX9N): Deleted.
1244         (MIN_CHAR_COMPOSITION): Deleted.
1245         (breakup_char_1): Use `MAX_CHAR_BASIC_LATIN' instead of
1246         `CHAR_ASCII_P'; use `0x7f' instead of `CHAR_FIELD3_INTERNAL'.
1247
1248 1999-09-02  MORIOKA Tomohiko  <tomo@m17n.org>
1249
1250         * buffer.h: Include mb-utf-8.h in UTF-2000.
1251
1252         * character.h (BUFBYTE_FIRST_BYTE_P): Moved to mb-utf-8.h.
1253
1254         * mb-utf-8.h: New file.
1255
1256 1999-09-02  MORIOKA Tomohiko  <tomo@etl.go.jp>
1257
1258         * chartab.h (CHAR_TABLE_NON_ASCII_VALUE_UNSAFE): Use `Charset_ID'
1259         instead of `int'.
1260
1261         * mule-charset.h, buffer.h (Charset_ID): New type.
1262
1263 1999-09-01  MORIOKA Tomohiko  <tomo@etl.go.jp>
1264
1265         * mule-canna.c (c2mu): Use `MAKE_CHAR',
1266         `Vcharset_japanese_jisx0212' and `Vcharset_japanese_jisx0208'
1267         instead of `MULE_CHAR_PRIVATE_OFFSET',
1268         `LEADING_BYTE_JAPANESE_JISX0212', `LEADING_BYTE_JAPANESE_JISX0208'
1269         and `FIELD1_TO_OFFICIAL_LEADING_BYTE'.
1270         (m2c): Use `BREAKUP_CHAR' and `XCHARSET_FINAL'.
1271
1272         * character.h (Vcharset_japanese_jisx0212): New variable
1273         definition.
1274
1275 1999-09-01  MORIOKA Tomohiko  <tomo@etl.go.jp>
1276
1277         * mule-charset.c (Vcharset_ucs_bmp): New variable in UTF-2000.
1278         (charset_by_attributes): Delete array about direction.
1279         (latin_a_char_to_charset): New variable in UTF-2000.
1280         (latin_a_char_to_byte1): New variable in UTF-2000.
1281         (latin_a_char_to_byte2): New variable in UTF-2000.
1282         (Qucs_bmp): New variable.
1283         (next_allocated_1_byte_leading_byte): Use `Charset_ID' instead of
1284         `Bufbyte'.
1285         (next_allocated_2_byte_leading_byte): Likewise.
1286         (non_ascii_set_charptr_emchar): Likewise.
1287         (make_charset): Likewise; add `CHARSET_TYPE_128X128' and
1288         `CHARSET_TYPE_256X256' in UTF-2000; modify for
1289         `charset_by_attributes'.
1290         (get_unallocated_leading_byte): Use `Charset_ID' instead of `int'.
1291         (char-charset): Use `CHAR_CHARSET' instead of `CHAR_LEADING_BYTE'
1292         and `CHARSET_BY_LEADING_BYTE'.
1293         (syms_of_mule_charset): Set up `ucs-bmp'; move setting of
1294         `utf-2000-version' to `vars_of_mule_charset'.
1295         (vars_of_mule_charset): Modify for `charset_by_attributes'; don't
1296         define `leading-code-private-11' in UTF-2000; move setting of
1297         `utf-2000-version' from `syms_of_mule_charset'.
1298         (complex_vars_of_mule_charset): Set up charset `ucs-bmp' in
1299         UTF-2000.
1300
1301         * character.h (Charset_ID): New type.
1302         (LEADING_BYTE_UCS_BMP): New macro.
1303         (LEADING_BYTE_CONTROL_1): Changed from 0x8F to 0x81.
1304         (CHARSET_ID_OFFSET_94): New macro.
1305         (MIN_CHARSET_ID_PRIVATE_94): New macro.
1306         (MAX_CHARSET_ID_PRIVATE_94): New macro.
1307         (LEADING_BYTE_ASCII): Changed to use CHARSET_ID_OFFSET_94 and
1308         final-byte.
1309         (LEADING_BYTE_KATAKANA_JISX0201): Likewise.
1310         (LEADING_BYTE_LATIN_JISX0201): Likewise.
1311         (CHARSET_ID_OFFSET_96): New macro.
1312         (LEADING_BYTE_LATIN_ISO8859_1): Changed to use
1313         CHARSET_ID_OFFSET_96 and final-byte.
1314         (LEADING_BYTE_LATIN_ISO8859_2): Likewise.
1315         (LEADING_BYTE_LATIN_ISO8859_3): Likewise.
1316         (LEADING_BYTE_LATIN_ISO8859_4): Likewise.
1317         (LEADING_BYTE_GREEK_ISO8859_7): Likewise.
1318         (LEADING_BYTE_ARABIC_ISO8859_6): Likewise.
1319         (LEADING_BYTE_HEBREW_ISO8859_8): Likewise.
1320         (LEADING_BYTE_CYRILLIC_ISO8859_5): Likewise.
1321         (LEADING_BYTE_LATIN_ISO8859_9): Likewise.
1322         (LEADING_BYTE_THAI_TIS620): Likewise.
1323         (MIN_LEADING_BYTE_PRIVATE_1): Changed from 0x0D0 to 0xD0.
1324         (MAX_LEADING_BYTE_PRIVATE_1): Changed from 0x11f to 0xDF.
1325         (CHARSET_ID_OFFSET_94x94): New macro.
1326         (LEADING_BYTE_CHINESE_BIG5_1): Changed to use
1327         CHARSET_ID_OFFSET_94x94 and final-byte.
1328         (LEADING_BYTE_CHINESE_BIG5_2): Likewise.
1329         (MIN_LEADING_BYTE_PRIVATE_2): Likewise.
1330         (MAX_LEADING_BYTE_PRIVATE_2): Likewise.
1331         (LEADING_BYTE_JAPANESE_JISX0208_1978): Likewise.
1332         (LEADING_BYTE_CHINESE_GB2312): Likewise.
1333         (LEADING_BYTE_JAPANESE_JISX0208): Likewise.
1334         (LEADING_BYTE_KOREAN_KSC5601): Likewise.
1335         (LEADING_BYTE_JAPANESE_JISX0212): Likewise.
1336         (LEADING_BYTE_CHINESE_CCITT_GB): Likewise.
1337         (LEADING_BYTE_CHINESE_CNS11643_*): Likewise.
1338         (LEADING_BYTE_KOREAN_KPS9566): Likewise.
1339         (CHARSET_TYPE_128X128): New macro.
1340         (CHARSET_TYPE_256X256): New macro.
1341         (XCHARSET_PRIVATE_P): Delete unconditionally.
1342         (charset_by_attributes): Delete array about direction.
1343         (CHARSET_BY_LEADING_BYTE): Use `Charset_ID' instead of `int'.
1344         (CHARSET_BY_ATTRIBUTES): Modify for `charset_by_attributes'.
1345         (MIN_CHAR_94): New macro.
1346         (MAX_CHAR_94): New macro.
1347         (MIN_CHAR_96): New macro.
1348         (MAX_CHAR_96): New macro.
1349         (MIN_CHAR_94x94): New macro.
1350         (MAX_CHAR_94x94): New macro.
1351         (MIN_CHAR_96x96): New macro.
1352         (MAX_CHAR_96x96): New macro.
1353         (FIELD1_TO_PRIVATE_LEADING_BYTE): Use `CHARSET_ID_OFFSET_94x94'.
1354         (FIELD1_TO_OFFICIAL_LEADING_BYTE): Likewise.
1355         (FIELD2_TO_PRIVATE_LEADING_BYTE): Use `(MIN_LEADING_BYTE_PRIVATE_1
1356         - 32)'.
1357         (FIELD2_TO_OFFICIAL_LEADING_BYTE): Use `LEADING_BYTE_ASCII'.
1358         (MIN_CHAR_FIELD2_OFFICIAL): Deleted.
1359         (MAX_CHAR_FIELD2_OFFICIAL): Deleted.
1360         (MIN_CHAR_OFFICIAL_TYPE9N): Deleted.
1361         (MAX_CHAR_PRIVATE_TYPE9N): Changed.
1362         (MAKE_CHAR): Use `XCHARSET_FINAL' instead of
1363         `XCHARSET_LEADING_BYTE' to make code-point.
1364         (latin_a_char_to_charset): New variable.
1365         (latin_a_char_to_byte1): New variable.
1366         (latin_a_char_to_byte2): New variable.
1367         (breakup_char_1): Use `latin_a_char_to_{charset|byte1|byte2}' for
1368         Latin Extended-A; use `CHARSET_BY_ATTRIBUTES' instead of
1369         `CHARSET_BY_LEADING_BYTE' to get charset for ISO-2022 characters.
1370
1371         * insdel.c (find_charsets_in_bufbyte_string): Use `Charset_ID'
1372         instead of `unsigned char'; use `MIN_LEADING_BYTE' instead of 128.
1373         (find_charsets_in_emchar_string): Likewise.
1374         (vars_of_insdel): Don't define local variable `i' in UTF-2000.
1375
1376         * file-coding.c (Fdecode_big5_char): Use `Charset_ID' instead of
1377         `int'.
1378         (decode_coding_iso2022): Likewise.
1379
1380         * toolbar-x.c (x_output_toolbar_button): Use `Charset_ID' instead
1381         of `unsigned char'.
1382
1383         * redisplay.c (redisplay_text_width_emchar_string): Use
1384         `Charset_ID' instead of `unsigned char'.
1385         (redisplay_frame_text_width_string): Likewise.
1386
1387         * glyphs.c (glyph_height_internal): Use `Charset_ID' instead of
1388         `unsigned char'.
1389
1390         * faces.h, faces.c (ensure_face_cachel_complete): Use `Charset_ID'
1391         instead of `unsigned char'.
1392         (face_cachel_charset_font_metric_info): Likewise.
1393
1394         * chartab.c (print_char_table): Use `Charset_ID' instead of `int'.
1395         (get_non_ascii_char_table_value): Likewise.
1396         (get_char_table): Likewise.
1397         (put_char_table): Likewise.
1398         (map_over_other_charset): Likewise.
1399         (map_char_table): Likewise.
1400
1401         * buffer.h (find_charsets_in_bufbyte_string): Use `Charset_ID'
1402         instead of `unsigned char'.
1403
1404 1999-08-31  MORIOKA Tomohiko  <tomo@etl.go.jp>
1405
1406         * character.h (PRE_LEADING_BYTE_PRIVATE_1): Deleted.
1407         (PRE_LEADING_BYTE_PRIVATE_2): Deleted.
1408
1409         * mule-charset.c (leading_code_private_11): Don't define in
1410         UTF-2000.
1411
1412         * mule-ccl.c (ccl_driver): Don't define `CCL_ReadMultibyteChar2'
1413         in UTF-2000 because it is not ported yet and not to use
1414         `PRE_LEADING_BYTE_PRIVATE_1' and `PRE_LEADING_BYTE_PRIVATE_2'.
1415
1416 1999-08-30  MORIOKA Tomohiko  <tomo@etl.go.jp>
1417
1418         * character.h (LEADING_BYTE_COMPOSITE): Deleted.
1419
1420 1999-08-29  MORIOKA Tomohiko  <tomo@etl.go.jp>
1421
1422         * regex.c (re_compile_fastmap): Don't use `LEADING_BYTE_PREFIX_P'
1423         in UTF-2000.
1424
1425         * chartab.h (CHAR_TABLE_NON_ASCII_VALUE_UNSAFE): Use int instead
1426         of unsigned char to store leading-byte.
1427
1428         * chartab.c (get_non_ascii_char_table_value): Don't use
1429         `BREAKUP_CHAR_1_UNSAFE' in UTF-2000.
1430
1431         * file-coding.c (encode_coding_big5): Delete bogus implementation
1432         in UTF2000.
1433
1434         * character.h (LEADING_BYTE_*): Delete definition for
1435         non-UTF-2000.
1436         (LEADING_BYTE_PRIVATE_P): Deleted unconditionally.
1437         (LEADING_BYTE_PREFIX_P): Deleted.
1438         (PRIVATE_LEADING_BYTE_PREFIX): Deleted.
1439         (BUFBYTE_FIRST_BYTE_P): Delete definition for non-UTF-2000.
1440         (BUFBYTE_LEADING_BYTE_P): Deleted.
1441         (CHARSET_PRIVATE_P): Deleted unconditionally.
1442         (rep_bytes_by_first_byte): Deleted unconditionally.
1443         (REP_BYTES_BY_FIRST_BYTE): Delete definition for non-UTF-2000.
1444         (FIELD1_TO_PRIVATE_LEADING_BYTE): Likewise.
1445         (FIELD1_TO_OFFICIAL_LEADING_BYTE): Likewise.
1446         (FIELD2_TO_PRIVATE_LEADING_BYTE): Likewise.
1447         (CHAR_FIELD2): Deleted.
1448         (CHAR_FIELD3): Deleted.
1449         (MAKE_CHAR): Delete definition for non-UTF-2000.
1450         (BREAKUP_CHAR_1_UNSAFE): Deleted.
1451         (breakup_char_1): New implementation.
1452         (CHAR_CHARSET): Use `BREAKUP_CHAR'.
1453         (CHAR_LEADING_BYTE): Use `CHAR_CHARSET'.
1454
1455 1999-08-29  MORIOKA Tomohiko  <tomo@etl.go.jp>
1456
1457         * character.h (REP_BYTES_BY_FIRST_BYTE): Change order of
1458         condition.
1459
1460 1999-08-28  MORIOKA Tomohiko  <tomo@etl.go.jp>
1461
1462         * character.h (LEADING_BYTE_PRIVATE_P): Don't define in UTF2000.
1463         (CHARSET_PRIVATE_P): Likewise.
1464         (XCHARSET_PRIVATE_P): Likewise.
1465         (MAKE_CHAR): Don't use XCHARSET_PRIVATE_P in UTF2000.
1466
1467         * file-coding.c (encode_coding_ucs4): Delete bogus implement in
1468         UTF2000.
1469         (decode_coding_iso2022): Don't use XCHARSET_PRIVATE_P in UTF2000.
1470
1471 1999-08-28  MORIOKA Tomohiko  <tomo@etl.go.jp>
1472
1473         * character.h (LEADING_BYTE_*): Changed in UTF2000.
1474         (NUM_LEADING_BYTES): Changed from 128 to 256.
1475         (FIELD1_TO_PRIVATE_LEADING_BYTE): Change value to 0x80 in UTF2000.
1476         (FIELD1_TO_OFFICIAL_LEADING_BYTE): Change value to 0x80 in
1477         UTF2000.
1478         (FIELD2_TO_PRIVATE_LEADING_BYTE): Change value to 0x80 in UTF2000.
1479
1480         * mule-charset.c (Vcharset_chinese_cns11643_3): New variable in
1481         UTF2000.
1482         (Vcharset_chinese_cns11643_4): New variable in UTF2000.
1483         (Vcharset_chinese_cns11643_5): New variable in UTF2000.
1484         (Vcharset_chinese_cns11643_6): New variable in UTF2000.
1485         (Vcharset_chinese_cns11643_7): New variable in UTF2000.
1486         (Qchinese_cns11643_3): New variable in UTF2000.
1487         (Qchinese_cns11643_4): New variable in UTF2000.
1488         (Qchinese_cns11643_5): New variable in UTF2000.
1489         (Qchinese_cns11643_6): New variable in UTF2000.
1490         (Qchinese_cns11643_7): New variable in UTF2000.
1491         (syms_of_mule_charset): Define `chinese-cns11643-3',
1492         `chinese-cns11643-4', `chinese-cns11643-5', `chinese-cns11643-6'
1493         and `chinese-cns11643-7' in UTF2000.
1494         (vars_of_mule_charset): Initialize
1495         next_allocated_2_byte_leading_byte by LEADING_BYTE_CHINESE_BIG5_2
1496         + 1 in UTF2000.
1497         (complex_vars_of_mule_charset): Setup charset
1498         `chinese-cns11643-3', `chinese-cns11643-4', `chinese-cns11643-5',
1499         `chinese-cns11643-6' and `chinese-cns11643-7' in UTF2000.
1500
1501 1999-08-27  MORIOKA Tomohiko  <tomo@etl.go.jp>
1502
1503         * mule-charset.c: Move setting for `leading-code-private-11' from
1504         `syms_of_mule_charset' to `vars_of_mule_charset'.
1505
1506 1999-08-27  MORIOKA Tomohiko  <tomo@etl.go.jp>
1507
1508         * mule-charset.h (CHARSET_BY_LEADING_BYTE): Use `MIN_LEADING_BYTE'
1509         and `NUM_LEADING_BYTES' in assert.
1510
1511 1999-08-27  MORIOKA Tomohiko  <tomo@etl.go.jp>
1512
1513         * character.h (charset_by_leading_byte): Use `NUM_LEADING_BYTES'
1514         instead of 128.
1515         (CHARSET_BY_LEADING_BYTE): Use `MIN_LEADING_BYTE' and
1516         `NUM_LEADING_BYTES' instead of 128.
1517
1518 1999-08-26  MORIOKA Tomohiko  <tomo@etl.go.jp>
1519
1520         * mule-charset.h (charset_by_leading_byte): Use
1521         `NUM_LEADING_BYTES' instead of 128.
1522         (CHARSET_BY_LEADING_BYTE): Use `MIN_LEADING_BYTE' instead of 128.
1523
1524         * mule-charset.c (charset_by_leading_byte): Use
1525         `NUM_LEADING_BYTES' instead of 128.
1526         (make_charset): Use `MIN_LEADING_BYTE' instead of 128.
1527
1528         * faces.h (FACE_CACHEL_FONT): Use `MIN_LEADING_BYTE' instead of
1529         128.
1530
1531 1999-08-25  MORIOKA Tomohiko  <tomo@etl.go.jp>
1532
1533         * mule-charset.c (syms_of_mule_charset): Update to
1534         0.4 (Shin-Imamiya).
1535
1536 1999-07-13 Daiki Ueno <ueno@ueda.info.waseda.ac.jp>
1537
1538         * file-coding.c (encode_coding_sjis): New implementation for
1539         UTF2000.  (decode_coding_sjis): Ditto.
1540
1541 1999-06-17  MORIOKA Tomohiko  <tomo@etl.go.jp>
1542
1543         * mule-charset.c, character.h (Bytecount rep_bytes_by_first_byte):
1544         Don't define in UTF2000.
1545
1546         * character.h: Include mule-charset.h if CHAR_IS_UCS4 is not
1547         defined.
1548
1549         * redisplay-msw.c, objects-tty.c, objects-msw.c, mule-wnnfns.c,
1550         mule-ccl.c, lstream.h, buffer.h: Include character.h in every
1551         MULE.
1552
1553 1999-06-17  MORIOKA Tomohiko  <tomo@etl.go.jp>
1554
1555         * config.h.in (CHAR_IS_UCS4): New macro.
1556
1557         * mule-charset.c (rep_bytes_by_first_byte): Modify for
1558         conventional MULE representation.
1559         (syms_of_mule_charset): Update to 0.3 (Imamiya).
1560
1561         * mule-charset.h: Reverted to original.
1562
1563         * redisplay-msw.c, objects-tty.c, objects-msw.c, mule-wnnfns.c,
1564         mule-ccl.c, lstream.h, buffer.h: Use "character.h" instead of
1565         "mule-charset.h" if CHAR_IS_UCS4 is defined.
1566
1567         * character.h: New file.
1568
1569         * file-coding.c (Fmake_coding_system): Set 1 to
1570         `codesys->fixed.size' if TYPE is `no-conversion' and UTF2000 is
1571         defined.
1572         (encode_coding_no_conversion): New implementation for UTF2000.
1573
1574         * file-coding.h (struct Lisp_Coding_System): Add new member
1575         `fixed.size'.
1576
1577 1999-06-16  MORIOKA Tomohiko  <tomo@etl.go.jp>
1578
1579         * file-coding.c (decode_coding_iso2022): Code-point arguments of
1580         `MAKE_CHAR' must be smaller than 0x80 in UTF2000.
1581         (encode_coding_iso2022): New implementation for UTF2000.
1582
1583 1999-06-15  MORIOKA Tomohiko  <tomo@etl.go.jp>
1584
1585         * mule-canna.c (c2mu): New implementation for UTF2000.
1586         (m2c): Likewise.
1587
1588 1999-06-15  MORIOKA Tomohiko  <tomo@etl.go.jp>
1589
1590         * file-coding.c (encode_coding_no_conversion): Modify for UTF2000.
1591
1592 1999-06-15  MORIOKA Tomohiko  <tomo@etl.go.jp>
1593
1594         * file-coding.c (reset_encoding_stream): Set 0 to
1595         `str->iso2022.current_char_boundary' in UTF2000.
1596         (encode_utf8): Don't define in UTF2000.
1597         (encode_coding_utf8): New implementation for UTF-8 representation
1598         of UTF2000.
1599         (complex_vars_of_file_coding): Define coding-system `utf-8'.
1600
1601 1999-06-15  MORIOKA Tomohiko  <tomo@etl.go.jp>
1602
1603         * mule.c (vars_of_mule): Provide `utf-2000' in UTF2000.
1604
1605         * mule-charset.h (BUFBYTE_FIRST_BYTE_P): Modify for UTF-8 in
1606         UTF2000.
1607         (REP_BYTES_BY_FIRST_BYTE): Likewise.
1608
1609         * buffer.h (non_ascii_valid_char_p): Don't define in UTF2000.
1610
1611         * mule-charset.c (non_ascii_set_charptr_emchar): Don't define
1612         local variables `lb', `c1', `c2' and `charset' in UTF2000; encode
1613         as UTF-8 in UTF2000.
1614         (non_ascii_charptr_emchar): Decode as UTF-8 in UTF2000.
1615         (non_ascii_valid_char_p): Don't define in UTF2000.
1616         (non_ascii_charptr_copy_char): Add case 5 and 6 in UTF2000.
1617         (Lstream_get_emchar_1): Likewise.
1618         (utf-2000-version): New variable in UTF2000.
1619
1620         * lread.c (read_escape): Add new reader `u'.
1621
1622         * insdel.c (three_to_one_table): Don't define in UTF2000.
1623         (bufpos_to_bytind_func): Use `buf->text->mule_size' instead of
1624         `buf->text->mule_shifter' and `buf->text->mule_three_p' in
1625         UTF2000.
1626         (bytind_to_bufpos_func): Likewise.
1627         (buffer_mule_signal_inserted_region): Likewise.
1628         (vars_of_insdel): Don't initialize `three_to_one_table'.
1629         (init_buffer_text): Use `buf->text->mule_size' instead of
1630         `buf->text->mule_shifter' and `buf->text->mule_three_p' in
1631         UTF2000.
1632
1633         * file-coding.c (DECODE_ADD_BINARY_CHAR): New implementation for
1634         UTF-8 representation in UTF2000.
1635         (DECODE_ADD_UCS_CHAR): New macro in UTF2000.
1636         (decode_ucs4): Use `DECODE_ADD_UCS_CHAR' in UTF2000.
1637         (decode_coding_iso2022): Don't define local variable `lb' in
1638         UTF2000; don't use LEADING_BYTE in UTF2000; use
1639         `DECODE_ADD_UCS_CHAR' in UTF2000.
1640         (convert_to_external_format): Decode as UTF-8 in UTF2000.
1641
1642         * config.h.in (UTF2000): New macro.
1643
1644         * buffer.h (struct buffer_text): Add new member `mule_size' and
1645         don't add `mule_shifter' and `mule_three_p' in UTF2000.
1646         (valid_char_p): Return always 1 in UTF2000.
1647         (MAX_EMCHAR_LEN): 6 in UTF2000.
1648         (three_to_one_table): Don't define in UTF2000.
1649         (real_bufpos_to_bytind): Modify for UTF-8 representation in
1650         UTF2000.
1651         (real_bytind_to_bufpos): Likewise.
1652
1653         * alloc.c (Fmake_string): Add case 5 and 6 for UTF2000.
1654
1655 1999-06-10  MORIOKA Tomohiko  <tomo@etl.go.jp>
1656
1657         * mule-charset.c (rep_bytes_by_first_byte): Modified for character
1658         representation change.
1659         (Vutf_2000_version): New variable.
1660         (leading_code_private_11): New variable.
1661         (syms_of_mule_charset): Add new variables `utf-2000-version' and
1662         `leading-code-private-11'.
1663
1664         * mule-charset.h (LEADING_BYTE_CHINESE_CCITT_GB): New macro.
1665         (LEADING_BYTE_CHINESE_BIG5_1): Changed to 0x96 temporally.
1666         (LEADING_BYTE_CHINESE_CNS11643_1): Changed to 0x97.
1667         (LEADING_BYTE_CHINESE_CNS11643_2): Changed to 0x98.
1668         (LEADING_BYTE_CHINESE_CNS11643_3): New macro.
1669         (LEADING_BYTE_CHINESE_CNS11643_4): Likewise.
1670         (LEADING_BYTE_CHINESE_CNS11643_5): Likewise.
1671         (LEADING_BYTE_CHINESE_CNS11643_6): Likewise.
1672         (LEADING_BYTE_CHINESE_CNS11643_7): Likewise [but not used].
1673         (LEADING_BYTE_CHINESE_BIG5_2): Changed to 0x9D temporally.
1674         (LEADING_BYTE_KOREAN_KPS9566): New macro [but not used].
1675         (CHAR_FIELD1_MASK): Changed to (0x7F << 14).
1676         (MIN_CHAR_GREEK): New macro.
1677         (MAX_CHAR_GREEK): New macro.
1678         (MIN_CHAR_CYRILLIC): New macro.
1679         (MAX_CHAR_CYRILLIC): New macro.
1680         (MIN_CHAR_HEBREW): New macro.
1681         (MAX_CHAR_HEBREW): New macro.
1682         (MIN_CHAR_THAI): New macro.
1683         (MAX_CHAR_THAI): New macro.
1684         (MIN_CHAR_HALFWIDTH_KATAKANA): New macro.
1685         (MAX_CHAR_HALFWIDTH_KATAKANA): New macro.
1686         (CHAR_FIELD2_INTERNAL): New macro [renamed from `CHAR_FIELD2'.
1687         (CHAR_FIELD3_INTERNAL): New macro [renamed from `CHAR_FIELD3'.
1688         (FIELD1_TO_PRIVATE_LEADING_BYTE): Changed to 0xc0.
1689         (FIELD1_TO_OFFICIAL_LEADING_BYTE): Changed to 0x50.
1690         (CHAR_FIELD2): New inline function.
1691         (CHAR_FIELD3): New inline function.
1692         (MULE_CHAR_PRIVATE_OFFSET): New macro.
1693         (MIN_CHAR_OFFICIAL_TYPE9N): Shifted to `MULE_CHAR_PRIVATE_OFFSET'.
1694         (MIN_CHAR_PRIVATE_TYPE9N): Likewise.
1695         (MIN_CHAR_PRIVATE_TYPE9NX9N): Likewise.
1696         (MIN_CHAR_OFFICIAL_TYPE9NX9N): Likewise.
1697         (MIN_CHAR_COMPOSITION): Likewise.
1698         (CHAR_LEADING_BYTE): Modified for character representation change.
1699         (MAKE_CHAR): Likewise.
1700
1701         * lisp.h (Vcharset_latin_iso8859_1): New variable.
1702         (Vcharset_greek_iso8859_7): Likewise.
1703         (Vcharset_cyrillic_iso8859_5): Likewise.
1704         (Vcharset_hebrew_iso8859_8): Likewise.
1705         (Vcharset_thai_tis620): Likewise.
1706         (Vcharset_katakana_jisx0201): Likewise.
1707
1708 2000-01-18  Martin Buchholz <martin@xemacs.org>
1709
1710         * XEmacs 21.2.27 is released.
1711
1712 2000-01-18  Martin Buchholz  <martin@xemacs.org>
1713
1714         * glyphs-eimage.c (struct tiff_error_struct):
1715         (tiff_error_func):
1716         (tiff_warning_func):
1717         #if HAVE_VSNPRINTF ==> #ifdef HAVE_VSNPRINTF
1718
1719         * unexmips.c:
1720         * unexhp9k3.c:
1721         * unexfreebsd.c:
1722         * unexec.c: Remove vestigial Lucid C code.
1723         * unexalpha.c:
1724         * unexaix.c:
1725         * termcap.c:
1726         * libsst.c: Ansify.
1727         Remove declarations of errno and strerror().
1728
1729         * eval.c (Fbacktrace): Small Purify-cation.  Fix docstring.
1730
1731         * .dbxrc (run-temacs): Use the horrible ${1+"$@"} instead of "$@".
1732
1733 2000-01-16  Martin Buchholz  <martin@xemacs.org>
1734
1735         * mule-charset.c (Fchar_octet): Resurrect from earlier in 1999.
1736         Optimize.
1737
1738 2000-01-14  Yoshiki Hayashi  <t90553@mail.ecc.u-tokyo.ac.jp>
1739
1740         * md5.c:
1741         * file-coding.c:
1742         * file-coding.h:
1743         Change enum eol_type to eol_type_t.
1744
1745 2000-01-17  Yoshiki Hayashi  <t90553@mail.ecc.u-tokyo.ac.jp>
1746
1747         * gui.c (get_gui_callback): Check cons before accessing car.
1748
1749 2000-01-17  Yoshiki Hayashi  <t90553@mail.ecc.u-tokyo.ac.jp>
1750
1751         * specifier.h (XSPECIFIER_TYPE): Add error checking version.
1752         (XSETSPECIFIER_TYPE): Ditto.
1753
1754 2000-01-17  Didier Verna  <didier@xemacs.org>
1755
1756         * redisplay.c (generate_fstring_runes): compute string size in
1757         characters, not bytes.
1758
1759 2000-01-09  Hrvoje Niksic  <hniksic@iskon.hr>
1760
1761         * window.c (Fwindow_minibuffer_p): Make WINDOW optional.
1762
1763 2000-01-14  Hrvoje Niksic  <hniksic@iskon.hr>
1764
1765         * print.c (print_error_message): Call print_prepare().
1766
1767 2000-01-14  Martin Buchholz  <martin@xemacs.org>
1768
1769         * .dbxrc: Renamed from dbxrc.
1770
1771         * events.c (event_to_character):
1772         Use `assert (foo)' instead of `if (!foo) abort()'
1773
1774         * .gdbinit (xtype): Add documentation.
1775         * .gdbinit (check-temacs): New function.
1776         * .gdbinit (check-xemacs): New function.
1777         * dbxrc (check-xemacs): New function.
1778         * dbxrc (check-xemacs): New function.
1779
1780 2000-01-14  Andy Piper  <andy@xemacs.org>
1781
1782         * glyphs-widget.c (widget_query_geometry): Make sure that we
1783         calculate default dimensions correctly.
1784
1785 2000-01-13  Kirill 'Big K' Katsnelson  <kkm@dtmx.com>
1786
1787         * symsinit.h: Added prototype for reinit_vars_of_frame_mswindows.
1788
1789         * event-msw.c (vars_of_event_mswindows): Fixed a mistyped
1790         pdump_wire'd variable.
1791
1792         * emacs.c: (main_1): Conditionalized calls to
1793         reinit_vars_of_scrollbar_x and reinit_vars_of_module.
1794
1795 2000-01-13  Martin Buchholz  <martin@xemacs.org>
1796
1797         * window.c (Fset_window_configuration):
1798         * sysdep.c (_start):
1799         * input-method-motif.c (res):
1800         * event-Xt.c (Xt_process_to_emacs_event):
1801         Simple compiler warning fixes.
1802
1803         * bytecode.c (funcall_compiled_function): Use the original
1804         function symbol on the backtrace list in preference to the
1805         compiled_function object in error messages.
1806
1807 2000-01-13  Andy Piper  <andy@xemacs.org>
1808
1809         * glyphs-x.c (update_widget_face): Make sure we update the widget
1810         background as well as foreground.
1811
1812 2000-01-13  Andy Piper  <andy@xemacs.org>
1813
1814         * glyphs.h (struct Lisp_Image_Instance): Move justify and orient
1815         fields to subwindow.
1816         (IMAGE_INSTANCE_SUBWINDOW_JUSTIFY): new macro.
1817         (XIMAGE_INSTANCE_SUBWINDOW_JUSTIFY): ditto.
1818         (IMAGE_INSTANCE_SUBWINDOW_ORIENT): ditto.
1819         (XIMAGE_INSTANCE_SUBWINDOW_ORIENT): ditto.
1820
1821         * glyphs-widget.c (check_valid_tab_orientation): new function.
1822         (initialize_widget_image_instance): zero orientation and
1823         justification.
1824         (widget_instantiate): pick up orientation.
1825         (tab_control_query_geometry): return appropriate values for
1826         vertical tabs.
1827
1828         * glyphs-msw.c: (mswindows_tab_control_instantiate): assign
1829         appropriate creation flags for left, right and bottom tabs.
1830
1831         * s/cygwin32.h: add tab definitions.
1832
1833 2000-01-12  Kirill 'Big K' Katsnelson  <kkm@dtmx.com>
1834
1835         * glyphs-msw.c (mswindows_unmap_subwindow): Set focus back to the
1836         frame upon hiding a subwindow.
1837         (mswindows_button_instantiate): Changed the push button style to
1838         BS_PUSHBUTTON.
1839         (mswindows_button_instantiate): Removed button BS_NOTIFY
1840         style.
1841         (mswindows_button_instantiate): Removed redundant check for
1842         a disabled gui item.
1843         (mswindows_button_instantiate): Made use of WS_TABSTOP
1844         consistent: "operable" controls (edit, button, tree, scroll) have
1845         this style, "display-only" ones (static, progress gauge) do
1846         not. This style is currently ignored by XEmacs though. Also,
1847         removed the WS_EX_CONTROLPARENT style - it is not for children,
1848         it is for their parents!
1849         (mswindows_edit_field_instantiate): Ditto.
1850         (mswindows_progress_gauge_instantiate): Ditto.
1851         (mswindows_tree_view_instantiate): Ditto.
1852         (mswindows_tab_control_instantiate): Ditto.
1853         (mswindows_scrollbar_instantiate): Ditto.
1854         (mswindows_combo_box_instantiate): Ditto.
1855         (mswindows_widget_instantiate): Added the WS_EX_CONTROLPARENT
1856         style to the "clip" window.
1857         (mswindows_button_instantiate): Removed compilation warning by
1858         equally typing terms of the ?: operator.
1859
1860 2000-01-12  Didier Verna  <didier@xemacs.org>
1861
1862         * redisplay.c (generate_fstring_runes): new parameter holding the
1863         last modeline-format extent.
1864         (add_glyph_to_fstring_db_runes): new parameter holding the glyph
1865         extent, fill the glyph block with it.
1866         (generate_fstring_runes): handle these parameters.
1867         (generate_formatted_string_db): ditto.
1868
1869         * keymap.c (get_relevant_keymaps): retreive the keymaps from the
1870         glyphs'extents in the modeline.
1871
1872 1999-01-11  Mike Woolley  <mike@bulsara.com>
1873
1874         * ntheap.c: Reduced the reserved heap space from 1Gb down to
1875         256Mb, as a workaround for the non-starting problem many people
1876         have experienced.
1877
1878 2000-01-06  Yoshiki Hayashi  <t90553@mail.ecc.u-tokyo.ac.jp>
1879
1880         * console-tty.c (Fset_console_tty_output_coding_system):
1881         Force redrawing tty frame.
1882
1883 2000-01-10  Didier Verna  <didier@xemacs.org>
1884
1885         * redisplay.c (generate_fstring_runes): fix size computation bug.
1886
1887 2000-01-09  William M. Perry <wmperry@aventail.com>
1888
1889         * gpmevent.c: (gpm_next_event_cb): Don't return value from void function.
1890
1891 2000-01-09  Andy Piper  <andy@xemacs.org>
1892
1893         * glyphs-msw.c: index -> i to avoid shadows.
1894         (xbm_create_bitmap_from_data): make static.
1895         (check_valid_string_or_int): deleted.
1896         (mswindows_control_wnd_proc): message -> msg to avoid shadows.
1897
1898         * glyphs-x.c (x_update_subwindow): remove unused args.
1899
1900         * glyphs.c (glyph_image_instance): return the thing. Don't set the
1901         back pointer - this is done in allocate_image_instance.
1902         (query_string_font): return Qnil to make the compiler happy.
1903         (unmap_subwindow): set to ~0 to make the compiler happy.
1904         (glyph_query_geometry): comment out until used.
1905         (glyph_layout): ditto.
1906
1907 2000-01-09  Hrvoje Niksic  <hniksic@iskon.hr>
1908
1909         * insdel.c (signal_after_change): Remove extraneous unbind_to().