xref: /titanic_50/usr/src/lib/iconv_modules/ja/common/japanese.h (revision 880d797826457b77414b37d531cc3e1aa166ecbe)
1*880d7978SAlexander Pyhalov /*
2*880d7978SAlexander Pyhalov  * CDDL HEADER START
3*880d7978SAlexander Pyhalov  *
4*880d7978SAlexander Pyhalov  * The contents of this file are subject to the terms of the
5*880d7978SAlexander Pyhalov  * Common Development and Distribution License (the "License").
6*880d7978SAlexander Pyhalov  * You may not use this file except in compliance with the License.
7*880d7978SAlexander Pyhalov  *
8*880d7978SAlexander Pyhalov  * You can obtain a copy of the license at src/OPENSOLARIS.LICENSE
9*880d7978SAlexander Pyhalov  * or http://www.opensolaris.org/os/licensing.
10*880d7978SAlexander Pyhalov  * See the License for the specific language governing permissions
11*880d7978SAlexander Pyhalov  * and limitations under the License.
12*880d7978SAlexander Pyhalov  *
13*880d7978SAlexander Pyhalov  * When distributing Covered Code, include this CDDL HEADER in each
14*880d7978SAlexander Pyhalov  * file and include the License file at src/OPENSOLARIS.LICENSE.
15*880d7978SAlexander Pyhalov  * If applicable, add the following below this CDDL HEADER, with the
16*880d7978SAlexander Pyhalov  * fields enclosed by brackets "[]" replaced with your own identifying
17*880d7978SAlexander Pyhalov  * information: Portions Copyright [yyyy] [name of copyright owner]
18*880d7978SAlexander Pyhalov  *
19*880d7978SAlexander Pyhalov  * CDDL HEADER END
20*880d7978SAlexander Pyhalov  */
21*880d7978SAlexander Pyhalov /*
22*880d7978SAlexander Pyhalov  * COPYRIGHT AND PERMISSION NOTICE
23*880d7978SAlexander Pyhalov  *
24*880d7978SAlexander Pyhalov  * Copyright (c) 1991-2005 Unicode, Inc. All rights reserved. Distributed
25*880d7978SAlexander Pyhalov  * under the Terms of Use in http://www.unicode.org/copyright.html.
26*880d7978SAlexander Pyhalov  *
27*880d7978SAlexander Pyhalov  * This file has been modified by Sun Microsystems, Inc.
28*880d7978SAlexander Pyhalov  */
29*880d7978SAlexander Pyhalov /*
30*880d7978SAlexander Pyhalov  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
31*880d7978SAlexander Pyhalov  * Use is subject to license terms.
32*880d7978SAlexander Pyhalov  */
33*880d7978SAlexander Pyhalov 
34*880d7978SAlexander Pyhalov 
35*880d7978SAlexander Pyhalov #define GET(c)		((c) = *ip, ip++, ileft--)
36*880d7978SAlexander Pyhalov #define PUT(c)		(*op = (c), op++, oleft--)
37*880d7978SAlexander Pyhalov #define UNGET()		(ip--, ileft++)
38*880d7978SAlexander Pyhalov 
39*880d7978SAlexander Pyhalov #if	defined(DEBUG)
40*880d7978SAlexander Pyhalov #include <stdio.h>
41*880d7978SAlexander Pyhalov static const char	*debugmsg = "<empty>";
42*880d7978SAlexander Pyhalov #define	DEBUGMSG(msg)	debugmsg = (msg);
43*880d7978SAlexander Pyhalov #else	/* ! DEBUG */
44*880d7978SAlexander Pyhalov #define	DEBUGMSG(msg)	;
45*880d7978SAlexander Pyhalov #endif	/* DEBUG */
46*880d7978SAlexander Pyhalov 
47*880d7978SAlexander Pyhalov #define	RETERROR(no, msg) {\
48*880d7978SAlexander Pyhalov 		errno = (no);\
49*880d7978SAlexander Pyhalov 		DEBUGMSG(msg);\
50*880d7978SAlexander Pyhalov 		rv = ((size_t)-1);\
51*880d7978SAlexander Pyhalov 		goto ret;\
52*880d7978SAlexander Pyhalov 	}
53*880d7978SAlexander Pyhalov 
54*880d7978SAlexander Pyhalov #if	defined(DEBUG)
55*880d7978SAlexander Pyhalov #define	DEBUGPRINTERROR \
56*880d7978SAlexander Pyhalov 	if (rv == (size_t)-1) { \
57*880d7978SAlexander Pyhalov 		if (errno == EILSEQ) { \
58*880d7978SAlexander Pyhalov 			fprintf(stderr, "DEBUG: EILSEQ: %s\n", debugmsg); \
59*880d7978SAlexander Pyhalov 		} else if (errno == E2BIG) { \
60*880d7978SAlexander Pyhalov 			fprintf(stderr, "DEBUG: E2BIG: %s\n", debugmsg); \
61*880d7978SAlexander Pyhalov 		} else if (errno == EINVAL) { \
62*880d7978SAlexander Pyhalov 			fprintf(stderr, "DEBUG: EINVAL: %s\n", debugmsg); \
63*880d7978SAlexander Pyhalov 		} else { \
64*880d7978SAlexander Pyhalov 			fprintf(stderr, \
65*880d7978SAlexander Pyhalov 			"DEBUG: errno=%d: %s\n", errno, debugmsg); \
66*880d7978SAlexander Pyhalov 		} \
67*880d7978SAlexander Pyhalov 	}
68*880d7978SAlexander Pyhalov #else	/* !DEBUG */
69*880d7978SAlexander Pyhalov #define	DEBUGPRINTERROR	/* nop */
70*880d7978SAlexander Pyhalov #endif	/* DEBUG */
71*880d7978SAlexander Pyhalov 
72*880d7978SAlexander Pyhalov #define NGET(c, msg) \
73*880d7978SAlexander Pyhalov 	if (ileft-- == 0) {\
74*880d7978SAlexander Pyhalov 		RETERROR(EINVAL, msg)\
75*880d7978SAlexander Pyhalov 	} else {\
76*880d7978SAlexander Pyhalov 		(c) = *ip++;\
77*880d7978SAlexander Pyhalov 	}
78*880d7978SAlexander Pyhalov 
79*880d7978SAlexander Pyhalov #define NPUT(c, msg) \
80*880d7978SAlexander Pyhalov 	if (oleft-- == 0) {\
81*880d7978SAlexander Pyhalov 		RETERROR(E2BIG, msg)\
82*880d7978SAlexander Pyhalov 	} else {\
83*880d7978SAlexander Pyhalov 		*op++ = (c);\
84*880d7978SAlexander Pyhalov 	}
85*880d7978SAlexander Pyhalov 
86*880d7978SAlexander Pyhalov /* to be obsoleted; migrate to PUTU() in jfp_iconv_unicode.h */
87*880d7978SAlexander Pyhalov #if	defined(JFP_ICONV_TOCODE_UCS2)
88*880d7978SAlexander Pyhalov #define	PUTUCS2(uni, msg)	\
89*880d7978SAlexander Pyhalov 	if (write_unicode((unsigned int)uni, &op, &oleft, little, msg) \
90*880d7978SAlexander Pyhalov 			== (size_t)-1) { \
91*880d7978SAlexander Pyhalov 		rv = ((size_t)-1);\
92*880d7978SAlexander Pyhalov 		goto ret; \
93*880d7978SAlexander Pyhalov 	}
94*880d7978SAlexander Pyhalov #else	/* !JFP_ICONV_TOCODE_UCS2 */
95*880d7978SAlexander Pyhalov #define	PUTUCS2(ucs2, msg)	\
96*880d7978SAlexander Pyhalov 	if (ucs2 <= 0x7f) {\
97*880d7978SAlexander Pyhalov 		NPUT((unsigned char)(ucs2), msg);\
98*880d7978SAlexander Pyhalov 	} else if (ucs2 <= 0x7ff) {\
99*880d7978SAlexander Pyhalov 		NPUT((unsigned char)((((ucs2)>>6) & 0x1f) | 0xc0), msg);\
100*880d7978SAlexander Pyhalov 		NPUT((unsigned char)((((ucs2)>>0) & 0x3f) | 0x80), msg);\
101*880d7978SAlexander Pyhalov 	} else {\
102*880d7978SAlexander Pyhalov 		NPUT((unsigned char)((((ucs2)>>12) & 0x0f) | 0xe0), msg);\
103*880d7978SAlexander Pyhalov 		NPUT((unsigned char)((((ucs2)>>6) & 0x3f) | 0x80), msg);\
104*880d7978SAlexander Pyhalov 		NPUT((unsigned char)((((ucs2)>>0) & 0x3f) | 0x80), msg);\
105*880d7978SAlexander Pyhalov 	}
106*880d7978SAlexander Pyhalov #endif	/* JFP_ICONV_TOCODE_UCS2 */
107*880d7978SAlexander Pyhalov 
108*880d7978SAlexander Pyhalov #if	defined(JFP_ICONV_STATELESS)
109*880d7978SAlexander Pyhalov 
110*880d7978SAlexander Pyhalov #include	<stdlib.h>
111*880d7978SAlexander Pyhalov 
112*880d7978SAlexander Pyhalov static void *
_icv_open_stateless(void)113*880d7978SAlexander Pyhalov _icv_open_stateless(void)
114*880d7978SAlexander Pyhalov {
115*880d7978SAlexander Pyhalov 	void	*cd;
116*880d7978SAlexander Pyhalov 
117*880d7978SAlexander Pyhalov 	/*
118*880d7978SAlexander Pyhalov 	 * Do malloc() only to get address as unique conversion descriptor.
119*880d7978SAlexander Pyhalov 	 * Though iconv() specification doesn't describe the uniqueness,
120*880d7978SAlexander Pyhalov 	 * some existing applications may be assuming it.
121*880d7978SAlexander Pyhalov 	 * Unless call of malloc() here is raised as a problem, keep away
122*880d7978SAlexander Pyhalov 	 * from breaking the assumption.
123*880d7978SAlexander Pyhalov 	 */
124*880d7978SAlexander Pyhalov 
125*880d7978SAlexander Pyhalov 	if ((cd = malloc((size_t)1)) == NULL) {
126*880d7978SAlexander Pyhalov 		errno = ENOMEM;
127*880d7978SAlexander Pyhalov 		return ((void *)-1);
128*880d7978SAlexander Pyhalov 	} else {
129*880d7978SAlexander Pyhalov 		return (cd);
130*880d7978SAlexander Pyhalov 	}
131*880d7978SAlexander Pyhalov }
132*880d7978SAlexander Pyhalov 
133*880d7978SAlexander Pyhalov static void
_icv_close_stateless(void * cd)134*880d7978SAlexander Pyhalov _icv_close_stateless(void *cd)
135*880d7978SAlexander Pyhalov {
136*880d7978SAlexander Pyhalov 	if (cd == NULL) {
137*880d7978SAlexander Pyhalov 		errno = EBADF;
138*880d7978SAlexander Pyhalov 	} else {
139*880d7978SAlexander Pyhalov 		free(cd);
140*880d7978SAlexander Pyhalov 	}
141*880d7978SAlexander Pyhalov 	return;
142*880d7978SAlexander Pyhalov }
143*880d7978SAlexander Pyhalov 
144*880d7978SAlexander Pyhalov #endif	/* ! JFP_ICONV_STATELESS */
145*880d7978SAlexander Pyhalov 
146*880d7978SAlexander Pyhalov #define ERR_RETURN	(-1)		/* result code on error */
147*880d7978SAlexander Pyhalov 
148*880d7978SAlexander Pyhalov /*
149*880d7978SAlexander Pyhalov  * ISXXXX(c) macros below assume (c) is of type unsigned char
150*880d7978SAlexander Pyhalov  */
151*880d7978SAlexander Pyhalov /* is a valid code as ascii? */
152*880d7978SAlexander Pyhalov #define ISASC(c)		((c) <= 0x7f)
153*880d7978SAlexander Pyhalov 
154*880d7978SAlexander Pyhalov /* is a valid code as C1 control? */
155*880d7978SAlexander Pyhalov #define ISC1CTRL(c)		(((c) >= 0x80) && ((c) <= 0x9f))
156*880d7978SAlexander Pyhalov 
157*880d7978SAlexander Pyhalov /* is a valid code as C1 control allowed in EUC? */
158*880d7978SAlexander Pyhalov #define ISC1CTRLEUC(c)		((((c) >= 0x80) && ((c) <= 0x8d)) ||\
159*880d7978SAlexander Pyhalov 					(((c) >= 0x90) && ((c) <= 0x9f)))
160*880d7978SAlexander Pyhalov 
161*880d7978SAlexander Pyhalov /* is a valid 1st or 2nd byte of EUC codeset 1? */
162*880d7978SAlexander Pyhalov #define ISCS1(c)		(((c) >= 0xa1) && ((c) <= 0xfe))
163*880d7978SAlexander Pyhalov 
164*880d7978SAlexander Pyhalov /* is a valid 1st byte of EUC codeset 1 and in range row 1 thru 84? */
165*880d7978SAlexander Pyhalov #define ISCS1_0208(c)		(((c) >= 0xa1) && ((c) <= 0xf4))
166*880d7978SAlexander Pyhalov 
167*880d7978SAlexander Pyhalov /* is a valid 1st byte of UDC area in EUC codeset 1? */
168*880d7978SAlexander Pyhalov #define ISCS1_UDC(c)		(((c) >= 0xf5) && ((c) <= 0xfe))
169*880d7978SAlexander Pyhalov 
170*880d7978SAlexander Pyhalov /* is a valid 2nd (1st byte is SS2) byte of EUC codeset 2? */
171*880d7978SAlexander Pyhalov #define ISCS2(c)		(((c) >= 0xa1) && ((c) <= 0xdf))
172*880d7978SAlexander Pyhalov 
173*880d7978SAlexander Pyhalov /* is a valid 2nd or 3rd (1st byte is SS3) byte of EUC codeset 3? */
174*880d7978SAlexander Pyhalov #define ISCS3(c)		(((c) >= 0xa1) && ((c) <= 0xfe))
175*880d7978SAlexander Pyhalov 
176*880d7978SAlexander Pyhalov /* is a valid 2nd (1st byte is SS3) byte of UDC area in EUC codeset 3? */
177*880d7978SAlexander Pyhalov #define ISCS3_UDC(c)		(((c) >= 0xf5) && ((c) <= 0xfe))
178*880d7978SAlexander Pyhalov 
179*880d7978SAlexander Pyhalov /* is a valid hankaku_katakana for SJIS? */
180*880d7978SAlexander Pyhalov #define ISSJKANA(c)		(((c) >= 0xa1) && ((c) <= 0xdf))
181*880d7978SAlexander Pyhalov 
182*880d7978SAlexander Pyhalov /* is a valid character for the first byte of SJIS multibyte? */
183*880d7978SAlexander Pyhalov #define ISSJMB_1(c)	((((c) >= 0x81) && ((c) <= 0x9f)) ||\
184*880d7978SAlexander Pyhalov 				 (((c) >= 0xe0) && ((c) <= 0xfc)))
185*880d7978SAlexander Pyhalov 
186*880d7978SAlexander Pyhalov /* is a valid character for the first byte of SJIS kanji? */
187*880d7978SAlexander Pyhalov #define ISSJKANJI1(c)	((((c) >= 0x81) && ((c) <= 0x9f)) ||\
188*880d7978SAlexander Pyhalov 				 (((c) >= 0xe0) && ((c) <= 0xea)) ||\
189*880d7978SAlexander Pyhalov 				 (((c) >= 0xf0) && ((c) <= 0xf4)))
190*880d7978SAlexander Pyhalov 
191*880d7978SAlexander Pyhalov /* is a valid character for the first byte of a part of Suppl. SJIS? */
192*880d7978SAlexander Pyhalov #define ISSJSUPKANJI1(c)	(((c) >= 0xf5) && ((c) <= 0xf9))
193*880d7978SAlexander Pyhalov 
194*880d7978SAlexander Pyhalov /* is a valid character for the first byte of SJIS UDC? */
195*880d7978SAlexander Pyhalov #define ISSJUDC_1(c)		(((c) >= 0xf0) && ((c) <= 0xf9))
196*880d7978SAlexander Pyhalov 
197*880d7978SAlexander Pyhalov /* is a valid character for the first byte of ibm character set */
198*880d7978SAlexander Pyhalov #define	ISSJIBM(c)		(((c) >= 0xfa) && ((c) <= 0xfc))
199*880d7978SAlexander Pyhalov 
200*880d7978SAlexander Pyhalov /* is a valid character for the first byte of ibm character set */
201*880d7978SAlexander Pyhalov #define	ISSJNECIBM(c)		(((c) >= 0xed) && ((c) <= 0xef))
202*880d7978SAlexander Pyhalov 
203*880d7978SAlexander Pyhalov /* is a valid character for the second byte of SJIS kanji? */
204*880d7978SAlexander Pyhalov #define ISSJKANJI2(c)	((((c) >= 0x40) && ((c) <= 0x7e)) ||\
205*880d7978SAlexander Pyhalov 					 (((c) >= 0x80) && ((c) <= 0xfc)))
206*880d7978SAlexander Pyhalov 
207*880d7978SAlexander Pyhalov /* is a valid character for UTF8 UDC ? */
208*880d7978SAlexander Pyhalov #define ISUTF8UDC(c)	(((c) >= 0xe000) && ((c) <= 0xf8ff))
209*880d7978SAlexander Pyhalov 
210*880d7978SAlexander Pyhalov #define CS_0			0		/* codeset 0 */
211*880d7978SAlexander Pyhalov #define CS_1			1		/* codeset 1 */
212*880d7978SAlexander Pyhalov #define CS_2			2		/* codeset 2 */
213*880d7978SAlexander Pyhalov #define CS_3			3		/* codeset 3 */
214*880d7978SAlexander Pyhalov 
215*880d7978SAlexander Pyhalov #define ST_INIT			0		/* init */
216*880d7978SAlexander Pyhalov #define ST_INCS1		1		/* in codeset 1 */
217*880d7978SAlexander Pyhalov #define ST_INCS2		2		/* in codeset 2 */
218*880d7978SAlexander Pyhalov #define ST_INCS3		3		/* in codeset 3 */
219*880d7978SAlexander Pyhalov #define ST_ESC			4		/* in ESC */
220*880d7978SAlexander Pyhalov #define ST_MBTOG0_1		5		/* in the designation of MB to G0 - 1 */
221*880d7978SAlexander Pyhalov #define ST_MBTOG0_2		6		/* in the designation of MB to G0 - 2 */
222*880d7978SAlexander Pyhalov #define ST_SBTOG0		7		/* in the designation of SB to G0 */
223*880d7978SAlexander Pyhalov #define ST_208REV_1		8		/* in the designation of JISX208-1990 */
224*880d7978SAlexander Pyhalov #define ST_208REV_2		9		/* in the designation of JISX208-1990 */
225*880d7978SAlexander Pyhalov #define ST_REV_AFT_ESC		10		/* in the designation of JISX208-1990 */
226*880d7978SAlexander Pyhalov #define ST_REV_AFT_MBTOG0_1	11		/* in the designation of JISX208-1990 */
227*880d7978SAlexander Pyhalov #define ST_REV_AFT_MBTOG0_2	12		/* in the designation of JISX208-1990 */
228*880d7978SAlexander Pyhalov 
229*880d7978SAlexander Pyhalov /*
230*880d7978SAlexander Pyhalov  * CODE SET 0
231*880d7978SAlexander Pyhalov  * ESC ( B   			: To ASCII
232*880d7978SAlexander Pyhalov  * ESC ( J			: To JIS X 0201 - 1976 ROMAN
233*880d7978SAlexander Pyhalov  * ESC ( @			: TO ISO 646 IRV
234*880d7978SAlexander Pyhalov  *
235*880d7978SAlexander Pyhalov  * CODE SET 1
236*880d7978SAlexander Pyhalov  * ESC & @ ESC $ ( B		: To JIS X 0208 - 1990
237*880d7978SAlexander Pyhalov  * ESC $ ( B			: To JIS X 0208 - 1983/1990
238*880d7978SAlexander Pyhalov  * ESC $ ( @			: To JIS X 0208 - 1978
239*880d7978SAlexander Pyhalov  * ESC $ B			: To JIS X 0208 - 1983/1990
240*880d7978SAlexander Pyhalov  * ESC $ @			: To JIS X 0208 - 1978
241*880d7978SAlexander Pyhalov  * ESC & @ ESC $ B		: To JIS X 0208 - 1983/1990
242*880d7978SAlexander Pyhalov  *
243*880d7978SAlexander Pyhalov  * CODE SET 2
244*880d7978SAlexander Pyhalov  * SO  					: G1 -> G
245*880d7978SAlexander Pyhalov  * SI  					: G0 -> G
246*880d7978SAlexander Pyhalov  * ESC ( I				: To JIS X 0201 - 1976 Katakana
247*880d7978SAlexander Pyhalov  *
248*880d7978SAlexander Pyhalov  * CODE SET 3
249*880d7978SAlexander Pyhalov  * ESC $ ( D			: To JIS X 0212 - 1990
250*880d7978SAlexander Pyhalov  * ESC $ D			: To JIS X 0212 - 1990
251*880d7978SAlexander Pyhalov  *
252*880d7978SAlexander Pyhalov  */
253*880d7978SAlexander Pyhalov 
254*880d7978SAlexander Pyhalov #define ESC				0x1b		/* Escape : 1/12 */
255*880d7978SAlexander Pyhalov #define SO				0x0e		/* Shift Out : 0/14 */
256*880d7978SAlexander Pyhalov #define SI				0x0f		/* Shift In  : 0/15 */
257*880d7978SAlexander Pyhalov 
258*880d7978SAlexander Pyhalov #define SBTOG0_1			0x28		/* ( : 2/8 */
259*880d7978SAlexander Pyhalov #define F_ASCII				0x42		/* B : 4/2 */
260*880d7978SAlexander Pyhalov #define F_X0201_RM			0x4a		/* J : 4/10 */
261*880d7978SAlexander Pyhalov #define F_ISO646			0x40		/* @ : 4/0 */
262*880d7978SAlexander Pyhalov #define F_X0201_KN			0x49		/* I : 4/9 */
263*880d7978SAlexander Pyhalov 
264*880d7978SAlexander Pyhalov #define MBTOG0_1			0x24		/* $ : 2/4 */
265*880d7978SAlexander Pyhalov #define MBTOG0_2			0x28		/* ( : 2/8 */
266*880d7978SAlexander Pyhalov #define F_X0208_83_90			0x42		/* B : 4/2 */
267*880d7978SAlexander Pyhalov #define F_X0208_78			0x40		/* @ : 4/0 */
268*880d7978SAlexander Pyhalov #define F_X0212_90			0x44		/* D : 4/4 */
269*880d7978SAlexander Pyhalov #define	X208REV_1			0x26		/* & : 2/6 */
270*880d7978SAlexander Pyhalov #define	X208REV_2			0x40		/* @ : 4/0 */
271*880d7978SAlexander Pyhalov 
272*880d7978SAlexander Pyhalov #define	CMASK				0x7f
273*880d7978SAlexander Pyhalov #define	CMSB				0x80
274*880d7978SAlexander Pyhalov 
275*880d7978SAlexander Pyhalov /* the byte length of ESC sequences */
276*880d7978SAlexander Pyhalov #define SEQ_SBTOG0			3			/* ESC + ( + F */
277*880d7978SAlexander Pyhalov #define SEQ_MBTOG0			4			/* ESC + $ + ( + F */
278*880d7978SAlexander Pyhalov #define SEQ_MBTOG0_O			3			/* ESC + $ + F */
279*880d7978SAlexander Pyhalov 
280*880d7978SAlexander Pyhalov /* the byte length of SO/SI */
281*880d7978SAlexander Pyhalov #define SEQ_SOSI			1			/* SO or SI */
282*880d7978SAlexander Pyhalov 
283*880d7978SAlexander Pyhalov /* the byte length of SS2/SS3 */
284*880d7978SAlexander Pyhalov #define SEQ_SS				1			/* SS2 or SS3 */
285*880d7978SAlexander Pyhalov 
286*880d7978SAlexander Pyhalov /* the byte length of JIS characters */
287*880d7978SAlexander Pyhalov #define JISW0				1			/* ASCII */
288*880d7978SAlexander Pyhalov #define JISW1				2			/* Kanji */
289*880d7978SAlexander Pyhalov #define JISW2				1			/* Hankaku Katakana */
290*880d7978SAlexander Pyhalov #define JISW3				2			/* Hojo Kanji */
291*880d7978SAlexander Pyhalov 
292*880d7978SAlexander Pyhalov /* the byte length of EUC characters */
293*880d7978SAlexander Pyhalov #define EUCW0				1			/* ASCII */
294*880d7978SAlexander Pyhalov #define EUCW1				2			/* Kanji */
295*880d7978SAlexander Pyhalov #define EUCW2				1			/* Hankaku Katakana */
296*880d7978SAlexander Pyhalov #define EUCW3				2			/* Hojo Kanji */
297*880d7978SAlexander Pyhalov #define SS2W				1			/* SS2 */
298*880d7978SAlexander Pyhalov #define SS3W				1			/* SS3 */
299*880d7978SAlexander Pyhalov 
300*880d7978SAlexander Pyhalov /* the byte length of SJIS characters */
301*880d7978SAlexander Pyhalov #define SJISW0				1			/* ASCII */
302*880d7978SAlexander Pyhalov #define SJISW1				2			/* Kanji/UDC */
303*880d7978SAlexander Pyhalov #define SJISW2				1			/* Hankaku Katakana */
304*880d7978SAlexander Pyhalov 
305*880d7978SAlexander Pyhalov #define EBCDIC0				1
306*880d7978SAlexander Pyhalov #define EBCDIC1				2
307*880d7978SAlexander Pyhalov #define EBCDIC2				1
308*880d7978SAlexander Pyhalov #define EBCDIC3				2
309*880d7978SAlexander Pyhalov 
310*880d7978SAlexander Pyhalov /* the byte length of unknown characters */
311*880d7978SAlexander Pyhalov #define UNKNOWNW			1
312*880d7978SAlexander Pyhalov 
313*880d7978SAlexander Pyhalov #define	TRUE	(1)
314*880d7978SAlexander Pyhalov #define	FALSE	(0)
315*880d7978SAlexander Pyhalov 
316*880d7978SAlexander Pyhalov /*
317*880d7978SAlexander Pyhalov  * sjtojis1[]:
318*880d7978SAlexander Pyhalov  * Directly convert 1st octet of Shift-JIS encoded 2bytes codes
319*880d7978SAlexander Pyhalov  * to the 1st octet of 7bit-JIS encoded 2bytes codes.
320*880d7978SAlexander Pyhalov  * Because the 8th bit is always ON, the size of this array
321*880d7978SAlexander Pyhalov  * can be limited to 128. (Precisely, 1st octet can vary between
322*880d7978SAlexander Pyhalov  * 0x81 and 0xfc, and correspondent 7bit-JIS value is between
323*880d7978SAlexander Pyhalov  * 0x21 and 0x7e. So we can use "0xff" as indicating invalid value.)
324*880d7978SAlexander Pyhalov  *
325*880d7978SAlexander Pyhalov  * Principal:
326*880d7978SAlexander Pyhalov  * 1: Subtract 0x80
327*880d7978SAlexander Pyhalov  * 2: Index the array by using the value above as index number.
328*880d7978SAlexander Pyhalov  * 3: Value "0xff" means the index number is invalid or, there's
329*880d7978SAlexander Pyhalov  *    no 7bit-JIS value that corresponds to.
330*880d7978SAlexander Pyhalov  *
331*880d7978SAlexander Pyhalov  * Note:
332*880d7978SAlexander Pyhalov  * 1: When the 2nd octet of Shift-JIS encoded 2bytes codes is
333*880d7978SAlexander Pyhalov  *    more than 0x9f, indexed value should be augumented by 1.
334*880d7978SAlexander Pyhalov  * 2: Some of Shift-JIS code points are mapped to JISX0208 plane
335*880d7978SAlexander Pyhalov  *    and others are JISX0212 plane.
336*880d7978SAlexander Pyhalov  *    Need to differentiate them before indexing and designate
337*880d7978SAlexander Pyhalov  *    appropriate character set. This table converts only code points
338*880d7978SAlexander Pyhalov  *    within each character set.
339*880d7978SAlexander Pyhalov  *
340*880d7978SAlexander Pyhalov  */
341*880d7978SAlexander Pyhalov static const unsigned char sjtojis1[] = {
342*880d7978SAlexander Pyhalov /* Values never be indexed */
343*880d7978SAlexander Pyhalov 0xff,
344*880d7978SAlexander Pyhalov /* Index 1KU - 62KU in JISX0208 */
345*880d7978SAlexander Pyhalov 0x21, 0x23, 0x25, 0x27, 0x29, 0x2b, 0x2d, 0x2f,
346*880d7978SAlexander Pyhalov 0x31, 0x33, 0x35, 0x37, 0x39, 0x3b, 0x3d, 0x3f,
347*880d7978SAlexander Pyhalov 0x41, 0x43, 0x45, 0x47, 0x49, 0x4b, 0x4d, 0x4f,
348*880d7978SAlexander Pyhalov 0x51, 0x53, 0x55, 0x57, 0x59, 0x5b, 0x5d,
349*880d7978SAlexander Pyhalov /* Values never be indexed */
350*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
351*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
352*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
353*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
354*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
355*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
356*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
357*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
358*880d7978SAlexander Pyhalov /* Index 63KU - 84KU in JISX0208 */
359*880d7978SAlexander Pyhalov                                           0x5f,
360*880d7978SAlexander Pyhalov 0x61, 0x63, 0x65, 0x67, 0x69, 0x6b, 0x6d, 0x6f,
361*880d7978SAlexander Pyhalov 0x71, 0x73,
362*880d7978SAlexander Pyhalov /* Values never be indexed */
363*880d7978SAlexander Pyhalov 0xff, 0xff,
364*880d7978SAlexander Pyhalov /* Followings will be mapped to 79KU - 84KU in JISX0212 (NEC/IBM) */
365*880d7978SAlexander Pyhalov /* 0x6f, 0x71, 0x73,						*/
366*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff,
367*880d7978SAlexander Pyhalov /* Followings will be mapped to 85KU - 94KU in JISX0208 (UDC) */
368*880d7978SAlexander Pyhalov 0x75, 0x77, 0x79, 0x7b, 0x7d,
369*880d7978SAlexander Pyhalov /* Followings will be mapped to 85KU - 94KU in JISX0212 (UDC) */
370*880d7978SAlexander Pyhalov 0x75, 0x77, 0x79, 0x7b, 0x7d,
371*880d7978SAlexander Pyhalov /* Followings will be mapped to 79KU - 84KU in JISX0212 (IBM) */
372*880d7978SAlexander Pyhalov /* 0x6f, 0x71, 0x73,						*/
373*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff,
374*880d7978SAlexander Pyhalov /* Values never be indexed */
375*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff
376*880d7978SAlexander Pyhalov };
377*880d7978SAlexander Pyhalov 
378*880d7978SAlexander Pyhalov /*
379*880d7978SAlexander Pyhalov  * sjtojis2[]:
380*880d7978SAlexander Pyhalov  * Directly convert 2nd octet of Shift-JIS encoded 2bytes codes
381*880d7978SAlexander Pyhalov  * to the 2nd octet of 7bit-JIS encoded 2bytes codes.
382*880d7978SAlexander Pyhalov  * 2nd octet in Shift-JIS can vary between 0x40 and 0xfc(except 0x7f)
383*880d7978SAlexander Pyhalov  * and the correspondent 7bit-JIS octet is between 0x21 and 0x7e.
384*880d7978SAlexander Pyhalov  * (So we can use '0xff' as indicating invalid value.)
385*880d7978SAlexander Pyhalov  *
386*880d7978SAlexander Pyhalov  * Principal:
387*880d7978SAlexander Pyhalov  * 1: Index the array by using the value above as index number.
388*880d7978SAlexander Pyhalov  * 2: Value "0xff" means the index number is invalid or, there's
389*880d7978SAlexander Pyhalov  *    no 7bit-JIS value that corresponds to.
390*880d7978SAlexander Pyhalov  *
391*880d7978SAlexander Pyhalov  * Note:
392*880d7978SAlexander Pyhalov  * 1: Some of Shift-JIS code points are mapped to JISX0208 plane
393*880d7978SAlexander Pyhalov  *    and others to JISX0212 plane.
394*880d7978SAlexander Pyhalov  *    Need to differentiate them before indexing and designate
395*880d7978SAlexander Pyhalov  *    appropriate character set. This table converts only code points
396*880d7978SAlexander Pyhalov  *    within each character set.
397*880d7978SAlexander Pyhalov  *
398*880d7978SAlexander Pyhalov  */
399*880d7978SAlexander Pyhalov static const unsigned char sjtojis2[] = {
400*880d7978SAlexander Pyhalov /* Values never be indexed */
401*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
402*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
403*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
404*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
405*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
406*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
407*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
408*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
409*880d7978SAlexander Pyhalov /* Followings are 2nd octet for 'odd' KU */
410*880d7978SAlexander Pyhalov 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28,
411*880d7978SAlexander Pyhalov 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, 0x30,
412*880d7978SAlexander Pyhalov 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38,
413*880d7978SAlexander Pyhalov 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, 0x40,
414*880d7978SAlexander Pyhalov 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48,
415*880d7978SAlexander Pyhalov 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f, 0x50,
416*880d7978SAlexander Pyhalov 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
417*880d7978SAlexander Pyhalov 0x59, 0x5a, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f,
418*880d7978SAlexander Pyhalov /* Values never be indexed */
419*880d7978SAlexander Pyhalov 0xff,
420*880d7978SAlexander Pyhalov /* Followings are 2nd octet for 'odd' KU */
421*880d7978SAlexander Pyhalov                                           0x60,
422*880d7978SAlexander Pyhalov 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68,
423*880d7978SAlexander Pyhalov 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f, 0x70,
424*880d7978SAlexander Pyhalov 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78,
425*880d7978SAlexander Pyhalov 0x79, 0x7a, 0x7b, 0x7c, 0x7d, 0x7e,
426*880d7978SAlexander Pyhalov /* Followings are 2nd octet for 'even' KU */
427*880d7978SAlexander Pyhalov 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28,
428*880d7978SAlexander Pyhalov 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, 0x30,
429*880d7978SAlexander Pyhalov 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38,
430*880d7978SAlexander Pyhalov 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, 0x40,
431*880d7978SAlexander Pyhalov 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48,
432*880d7978SAlexander Pyhalov 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e, 0x4f, 0x50,
433*880d7978SAlexander Pyhalov 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
434*880d7978SAlexander Pyhalov 0x59, 0x5a, 0x5b, 0x5c, 0x5d, 0x5e, 0x5f, 0x60,
435*880d7978SAlexander Pyhalov 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68,
436*880d7978SAlexander Pyhalov 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f, 0x70,
437*880d7978SAlexander Pyhalov 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78,
438*880d7978SAlexander Pyhalov 0x79, 0x7a, 0x7b, 0x7c, 0x7d, 0x7e,
439*880d7978SAlexander Pyhalov /* Values never be indexed */
440*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff
441*880d7978SAlexander Pyhalov };
442*880d7978SAlexander Pyhalov 
443*880d7978SAlexander Pyhalov /*
444*880d7978SAlexander Pyhalov  * sjtoibmext[]:
445*880d7978SAlexander Pyhalov  * Directly convert Shift-JIS encoded 2bytes codes
446*880d7978SAlexander Pyhalov  * to the EUC encoded 2bytes codes.
447*880d7978SAlexander Pyhalov  * This table is used for "IBM Extended Character Set" only.
448*880d7978SAlexander Pyhalov  *
449*880d7978SAlexander Pyhalov  * Principal:
450*880d7978SAlexander Pyhalov  * 1: Subtract 0xfa40.
451*880d7978SAlexander Pyhalov  * 2: Index the array by using the value above as index number.
452*880d7978SAlexander Pyhalov  * 3: Value "0xffff" means the index number is invalid or, there's
453*880d7978SAlexander Pyhalov  *    no EUC value that corresponds to.
454*880d7978SAlexander Pyhalov  *
455*880d7978SAlexander Pyhalov  * Note: The SJIS code points, 0xfa54 and 0xfa5b are mapped to JIS208
456*880d7978SAlexander Pyhalov  *       hence they are NOT mapped with tables below.
457*880d7978SAlexander Pyhalov  *       (They are mapped to 0xa2cc and 0xa2e8 in JIS208 respectively.)
458*880d7978SAlexander Pyhalov  */
459*880d7978SAlexander Pyhalov static const unsigned short sjtoibmext[] = {
460*880d7978SAlexander Pyhalov 0xf3f3, 0xf3f4, 0xf3f5, 0xf3f6, 0xf3f7, 0xf3f8, 0xf3f9, 0xf3fa, /* 0xfa47 */
461*880d7978SAlexander Pyhalov 0xf3fb, 0xf3fc, 0xf3fd, 0xf3fe, 0xf4a1, 0xf4a2, 0xf4a3, 0xf4a4,
462*880d7978SAlexander Pyhalov 0xf4a5, 0xf4a6, 0xf4a7, 0xf4a8, 0xffff, 0xa2c3, 0xf4a9, 0xf4aa,
463*880d7978SAlexander Pyhalov 0xf4ab, 0xf4ac, 0xf4ad, 0xffff, 0xd4e3, 0xdcdf, 0xe4e9, 0xe3f8,
464*880d7978SAlexander Pyhalov 0xd9a1, 0xb1bb, 0xf4ae, 0xc2ad, 0xc3fc, 0xe4d0, 0xc2bf, 0xbcf4,
465*880d7978SAlexander Pyhalov 0xb0a9, 0xb0c8, 0xf4af, 0xb0d2, 0xb0d4, 0xb0e3, 0xb0ee, 0xb1a7,
466*880d7978SAlexander Pyhalov 0xb1a3, 0xb1ac, 0xb1a9, 0xb1be, 0xb1df, 0xb1d8, 0xb1c8, 0xb1d7,
467*880d7978SAlexander Pyhalov 0xb1e3, 0xb1f4, 0xb1e1, 0xb2a3, 0xf4b0, 0xb2bb, 0xb2e6, 0xffff,
468*880d7978SAlexander Pyhalov 0xb2ed, 0xb2f5, 0xb2fc, 0xf4b1, 0xb3b5, 0xb3d8, 0xb3db, 0xb3e5,
469*880d7978SAlexander Pyhalov 0xb3ee, 0xb3fb, 0xf4b2, 0xf4b3, 0xb4c0, 0xb4c7, 0xb4d0, 0xb4de,
470*880d7978SAlexander Pyhalov 0xf4b4, 0xb5aa, 0xf4b5, 0xb5af, 0xb5c4, 0xb5e8, 0xf4b6, 0xb7c2,
471*880d7978SAlexander Pyhalov 0xb7e4, 0xb7e8, 0xb7e7, 0xf4b7, 0xf4b8, 0xf4b9, 0xb8ce, 0xb8e1,
472*880d7978SAlexander Pyhalov 0xb8f5, 0xb8f7, 0xb8f8, 0xb8fc, 0xb9af, 0xb9b7, 0xbabe, 0xbadb,
473*880d7978SAlexander Pyhalov 0xcdaa, 0xbae1, 0xf4ba, 0xbaeb, 0xbbb3, 0xbbb8, 0xf4bb, 0xbbca,
474*880d7978SAlexander Pyhalov 0xf4bc, 0xf4bd, 0xbbd0, 0xbbde, 0xbbf4, 0xbbf5, 0xbbf9, 0xbce4,
475*880d7978SAlexander Pyhalov 0xbced, 0xbcfe, 0xf4be, 0xbdc2, 0xbde7, 0xf4bf, 0xbdf0, 0xbeb0,
476*880d7978SAlexander Pyhalov 0xbeac, 0xf4c0, 0xbeb3, 0xbebd, 0xbecd, 0xbec9, 0xbee4, 0xbfa8,
477*880d7978SAlexander Pyhalov 0xbfc9, 0xc0c4, 0xc0e4, 0xc0f4, 0xc1a6, 0xf4c1, 0xc1f5, 0xc1fc,
478*880d7978SAlexander Pyhalov 0xf4c2, 0xc1f8, 0xc2ab, 0xc2a1, 0xc2a5, 0xf4c3, 0xc2b8, 0xc2ba,
479*880d7978SAlexander Pyhalov 0xf4c4, 0xc2c4, 0xc2d2, 0xc2d7, 0xc2db, 0xc2de, 0xc2ed, 0xc2f0,
480*880d7978SAlexander Pyhalov 0xf4c5, 0xc3a1, 0xc3b5, 0xc3c9, 0xc3b9, 0xf4c6, 0xc3d8, 0xc3fe,
481*880d7978SAlexander Pyhalov 0xf4c7, 0xc4cc, 0xf4c8, 0xc4d9, 0xc4ea, 0xc4fd, 0xf4c9, 0xc5a7,
482*880d7978SAlexander Pyhalov 0xc5b5, 0xc5b6, 0xf4ca, 0xc5d5, 0xc6b8, 0xc6d7, 0xc6e0, 0xc6ea,
483*880d7978SAlexander Pyhalov 0xc6e3, 0xc7a1, 0xc7ab, 0xc7c7, 0xc7c3, 0xffff, 0xffff, 0xffff,
484*880d7978SAlexander Pyhalov 0xc7cb, 0xc7cf, 0xc7d9, 0xf4cb, 0xf4cc, 0xc7e6, 0xc7ee, 0xc7fc, /* 0xfb47 */
485*880d7978SAlexander Pyhalov 0xc7eb, 0xc7f0, 0xc8b1, 0xc8e5, 0xc8f8, 0xc9a6, 0xc9ab, 0xc9ad,
486*880d7978SAlexander Pyhalov 0xf4cd, 0xc9ca, 0xc9d3, 0xc9e9, 0xc9e3, 0xc9fc, 0xc9f4, 0xc9f5,
487*880d7978SAlexander Pyhalov 0xf4ce, 0xcab3, 0xcabd, 0xcaef, 0xcaf1, 0xcbae, 0xf4cf, 0xcbca,
488*880d7978SAlexander Pyhalov 0xcbe6, 0xcbea, 0xcbf0, 0xcbf4, 0xcbee, 0xcca5, 0xcbf9, 0xccab,
489*880d7978SAlexander Pyhalov 0xccae, 0xccad, 0xccb2, 0xccc2, 0xccd0, 0xccd9, 0xf4d0, 0xcdbb,
490*880d7978SAlexander Pyhalov 0xf4d1, 0xcebb, 0xf4d2, 0xceba, 0xcec3, 0xf4d3, 0xcef2, 0xb3dd,
491*880d7978SAlexander Pyhalov 0xcfd5, 0xcfe2, 0xcfe9, 0xcfed, 0xf4d4, 0xf4d5, 0xf4d6, 0xffff,
492*880d7978SAlexander Pyhalov 0xf4d7, 0xd0e5, 0xf4d8, 0xd0e9, 0xd1e8, 0xf4d9, 0xf4da, 0xd1ec,
493*880d7978SAlexander Pyhalov 0xd2bb, 0xf4db, 0xd3e1, 0xd3e8, 0xd4a7, 0xf4dc, 0xf4dd, 0xd4d4,
494*880d7978SAlexander Pyhalov 0xd4f2, 0xd5ae, 0xf4de, 0xd7de, 0xf4df, 0xd8a2, 0xd8b7, 0xd8c1,
495*880d7978SAlexander Pyhalov 0xd8d1, 0xd8f4, 0xd9c6, 0xd9c8, 0xd9d1, 0xf4e0, 0xf4e1, 0xf4e2,
496*880d7978SAlexander Pyhalov 0xf4e3, 0xf4e4, 0xdcd3, 0xddc8, 0xddd4, 0xddea, 0xddfa, 0xdea4,
497*880d7978SAlexander Pyhalov 0xdeb0, 0xf4e5, 0xdeb5, 0xdecb, 0xf4e6, 0xdfb9, 0xf4e7, 0xdfc3,
498*880d7978SAlexander Pyhalov 0xf4e8, 0xf4e9, 0xe0d9, 0xf4ea, 0xf4eb, 0xe1e2, 0xf4ec, 0xf4ed,
499*880d7978SAlexander Pyhalov 0xf4ee, 0xe2c7, 0xe3a8, 0xe3a6, 0xe3a9, 0xe3af, 0xe3b0, 0xe3aa,
500*880d7978SAlexander Pyhalov 0xe3ab, 0xe3bc, 0xe3c1, 0xe3bf, 0xe3d5, 0xe3d8, 0xe3d6, 0xe3df,
501*880d7978SAlexander Pyhalov 0xe3e3, 0xe3e1, 0xe3d4, 0xe3e9, 0xe4a6, 0xe3f1, 0xe3f2, 0xe4cb,
502*880d7978SAlexander Pyhalov 0xe4c1, 0xe4c3, 0xe4be, 0xf4ef, 0xe4c0, 0xe4c7, 0xe4bf, 0xe4e0,
503*880d7978SAlexander Pyhalov 0xe4de, 0xe4d1, 0xf4f0, 0xe4dc, 0xe4d2, 0xe4db, 0xe4d4, 0xe4fa,
504*880d7978SAlexander Pyhalov 0xe4ef, 0xe5b3, 0xe5bf, 0xe5c9, 0xe5d0, 0xe5e2, 0xe5ea, 0xe5eb,
505*880d7978SAlexander Pyhalov 0xf4f1, 0xf4f2, 0xf4f3, 0xe6e8, 0xe6ef, 0xe7ac, 0xf4f4, 0xe7ae,
506*880d7978SAlexander Pyhalov 0xf4f5, 0xe7b1, 0xf4f6, 0xe7b2, 0xe8b1, 0xe8b6, 0xf4f7, 0xf4f8,
507*880d7978SAlexander Pyhalov 0xe8dd, 0xf4f9, 0xf4fa, 0xe9d1, 0xf4fb, 0xffff, 0xffff, 0xffff,
508*880d7978SAlexander Pyhalov 0xe9ed, 0xeacd, 0xf4fc, 0xeadb, 0xeae6, 0xeaea, 0xeba5, 0xebfb, /* 0xfc47 */
509*880d7978SAlexander Pyhalov 0xebfa, 0xf4fd, 0xecd6, 0xf4fe, 0xffff, 0xffff, 0xffff, 0xffff,
510*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
511*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
512*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
513*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
514*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
515*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
516*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
517*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
518*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
519*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
520*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
521*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
522*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
523*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
524*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
525*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
526*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
527*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
528*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
529*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
530*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff,
531*880d7978SAlexander Pyhalov 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff
532*880d7978SAlexander Pyhalov };
533*880d7978SAlexander Pyhalov /*
534*880d7978SAlexander Pyhalov  * jis208tosj1[]:
535*880d7978SAlexander Pyhalov  * Directly convert 1st octet of JISX0208 encoded 2bytes codes
536*880d7978SAlexander Pyhalov  * to the 1st octet of Shift-JIS encoded 2bytes codes.
537*880d7978SAlexander Pyhalov  * Because the 8th bit is always OFF, the size of this array
538*880d7978SAlexander Pyhalov  * can be limited to 128. (Precisely, 1st octet can vary between
539*880d7978SAlexander Pyhalov  * 0x21 and 0x7e, and the correspondent Shift-JIS code is
540*880d7978SAlexander Pyhalov  * between 0x81 and 0xfc. So we can use "0xff" as indicating invalid
541*880d7978SAlexander Pyhalov  * value.)
542*880d7978SAlexander Pyhalov  *
543*880d7978SAlexander Pyhalov  * Principal:
544*880d7978SAlexander Pyhalov  * 1: Index the array by using the value above as index number.
545*880d7978SAlexander Pyhalov  * 2: Value "0xff" means the index number is invalid or, there's
546*880d7978SAlexander Pyhalov  *    no Shift-JIS value that corresponds to.
547*880d7978SAlexander Pyhalov  *
548*880d7978SAlexander Pyhalov  * Note:
549*880d7978SAlexander Pyhalov  * 1: Some of Shift-JIS code points are mapped to JISX0208 plane
550*880d7978SAlexander Pyhalov  *    and others to JISX0212 plane.
551*880d7978SAlexander Pyhalov  *    Need to differentiate them before indexing and designate
552*880d7978SAlexander Pyhalov  *    appropriate character set. This table converts only code points
553*880d7978SAlexander Pyhalov  *    within each character set.
554*880d7978SAlexander Pyhalov  *
555*880d7978SAlexander Pyhalov  */
556*880d7978SAlexander Pyhalov static const unsigned char jis208tosj1[] = {
557*880d7978SAlexander Pyhalov /* Values never be indexed */
558*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
559*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
560*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
561*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
562*880d7978SAlexander Pyhalov 0xff,
563*880d7978SAlexander Pyhalov /* Index 1KU - 62KU in JISX0208 */
564*880d7978SAlexander Pyhalov       0x81, 0x81, 0x82, 0x82, 0x83, 0x83, 0x84,
565*880d7978SAlexander Pyhalov 0x84, 0x85, 0x85, 0x86, 0x86, 0x87, 0x87, 0x88,
566*880d7978SAlexander Pyhalov 0x88, 0x89, 0x89, 0x8a, 0x8a, 0x8b, 0x8b, 0x8c,
567*880d7978SAlexander Pyhalov 0x8c, 0x8d, 0x8d, 0x8e, 0x8e, 0x8f, 0x8f, 0x90,
568*880d7978SAlexander Pyhalov 0x90, 0x91, 0x91, 0x92, 0x92, 0x93, 0x93, 0x94,
569*880d7978SAlexander Pyhalov 0x94, 0x95, 0x95, 0x96, 0x96, 0x97, 0x97, 0x98,
570*880d7978SAlexander Pyhalov 0x98, 0x99, 0x99, 0x9a, 0x9a, 0x9b, 0x9b, 0x9c,
571*880d7978SAlexander Pyhalov 0x9c, 0x9d, 0x9d, 0x9e, 0x9e, 0x9f, 0x9f,
572*880d7978SAlexander Pyhalov /* Index 63KU - 84KU in JISX0208 */
573*880d7978SAlexander Pyhalov                                           0xe0,
574*880d7978SAlexander Pyhalov 0xe0, 0xe1, 0xe1, 0xe2, 0xe2, 0xe3, 0xe3, 0xe4,
575*880d7978SAlexander Pyhalov 0xe4, 0xe5, 0xe5, 0xe6, 0xe6, 0xe7, 0xe7, 0xe8,
576*880d7978SAlexander Pyhalov 0xe8, 0xe9, 0xe9, 0xea, 0xea,
577*880d7978SAlexander Pyhalov /* Followings are mapped to "UDC" area in Shift-JIS */
578*880d7978SAlexander Pyhalov                               0xf0, 0xf0, 0xf1,
579*880d7978SAlexander Pyhalov 0xf1, 0xf2, 0xf2, 0xf3, 0xf3, 0xf4, 0xf4,
580*880d7978SAlexander Pyhalov /* Values never be indexed */
581*880d7978SAlexander Pyhalov 0xff
582*880d7978SAlexander Pyhalov };
583*880d7978SAlexander Pyhalov 
584*880d7978SAlexander Pyhalov /*
585*880d7978SAlexander Pyhalov  * jis212tosj1[]:
586*880d7978SAlexander Pyhalov  * Directly convert 1st octet of JISX0212 encoded 2bytes codes
587*880d7978SAlexander Pyhalov  * to the 1st octet of Shift-JIS encoded 2bytes codes.
588*880d7978SAlexander Pyhalov  * Because the 8th bit is always OFF, the size of this array
589*880d7978SAlexander Pyhalov  * can be limited to 128. (Precisely, 1st octet can vary between
590*880d7978SAlexander Pyhalov  * 0x21 and 0x7e, and the correspondent Shift-JIS code is
591*880d7978SAlexander Pyhalov  * between 0x81 and 0xfc. So we can use "0xff" as indicating invalid
592*880d7978SAlexander Pyhalov  * value.)
593*880d7978SAlexander Pyhalov  *
594*880d7978SAlexander Pyhalov  * Principal:
595*880d7978SAlexander Pyhalov  * 1: Index the array by using the value above as index number.
596*880d7978SAlexander Pyhalov  * 2: Value "0xff" means the index number is invalid or, there's
597*880d7978SAlexander Pyhalov  *    no Shift-JIS value that corresponds to.
598*880d7978SAlexander Pyhalov  *
599*880d7978SAlexander Pyhalov  * Note:
600*880d7978SAlexander Pyhalov  * 1: Most G3 characters cannot map to Shift-JIS coded space.
601*880d7978SAlexander Pyhalov  *    (Such characters are mapped to unique code point. In this
602*880d7978SAlexander Pyhalov  *    table, it is 0x222e in JISX0208.)
603*880d7978SAlexander Pyhalov  * 2: Some of Shift-JIS code points are mapped to JISX0208 plane
604*880d7978SAlexander Pyhalov  *    and others to JISX0212 plane.
605*880d7978SAlexander Pyhalov  *    Need to differentiate them before indexing and designate
606*880d7978SAlexander Pyhalov  *    appropriate character set. This table converts only code points
607*880d7978SAlexander Pyhalov  *    within each character set.
608*880d7978SAlexander Pyhalov  *
609*880d7978SAlexander Pyhalov  */
610*880d7978SAlexander Pyhalov static const unsigned char jis212tosj1[] = {
611*880d7978SAlexander Pyhalov /* Values never be indexed */
612*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
613*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
614*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
615*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
616*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
617*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
618*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
619*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
620*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
621*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
622*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
623*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
624*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
625*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
626*880d7978SAlexander Pyhalov /* Followings are mapped to "NEC/IBM(?)" area in Shift-JIS */
627*880d7978SAlexander Pyhalov /*                                          0xfa,	*/
628*880d7978SAlexander Pyhalov /* 0xfa, 0xfb, 0xfb, 0xfc, 0xfc,			*/
629*880d7978SAlexander Pyhalov                                           0xff,
630*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff,
631*880d7978SAlexander Pyhalov /* Followings are mapped to "UDC" area in Shift-JIS */
632*880d7978SAlexander Pyhalov                               0xf5, 0xf5, 0xf6,
633*880d7978SAlexander Pyhalov 0xf6, 0xf7, 0xf7, 0xf8, 0xf8, 0xf9, 0xf9,
634*880d7978SAlexander Pyhalov /* Values never be indexed */
635*880d7978SAlexander Pyhalov 0xff
636*880d7978SAlexander Pyhalov };
637*880d7978SAlexander Pyhalov 
638*880d7978SAlexander Pyhalov /*
639*880d7978SAlexander Pyhalov  * jistosj2[]:
640*880d7978SAlexander Pyhalov  * Directly convert 2nd octet of 7bit-JIS encoded 2bytes codes
641*880d7978SAlexander Pyhalov  * to the 2nd octet of Shift-JIS encoded 2bytes codes.
642*880d7978SAlexander Pyhalov  * Although the source code may have the same value between
643*880d7978SAlexander Pyhalov  * JISX0208 and JISX0212, the destination code point can vary with regard to
644*880d7978SAlexander Pyhalov  * the eveness(oddness) of 'KU' number.
645*880d7978SAlexander Pyhalov  *
646*880d7978SAlexander Pyhalov  * Principal:
647*880d7978SAlexander Pyhalov  * 1: Add 0x80 if 'KU' number is even.
648*880d7978SAlexander Pyhalov  * 2: Index the array by using the value above as index number.
649*880d7978SAlexander Pyhalov  * 3: Value "0xff" means the index number is invalid or, there's
650*880d7978SAlexander Pyhalov  *    no Shift-JIS value that corresponds to.
651*880d7978SAlexander Pyhalov  *
652*880d7978SAlexander Pyhalov  * Note:
653*880d7978SAlexander Pyhalov  * 1: Use this table to map the 2nd octet of both JISX0208
654*880d7978SAlexander Pyhalov  *    and JISX0212.
655*880d7978SAlexander Pyhalov  *
656*880d7978SAlexander Pyhalov  */
657*880d7978SAlexander Pyhalov static const unsigned char jistosj2[] = {
658*880d7978SAlexander Pyhalov /* Values never be indexed */
659*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
660*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
661*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
662*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
663*880d7978SAlexander Pyhalov 0xff,
664*880d7978SAlexander Pyhalov /* Index 1TEN - 63TEN in 'odd KU' */
665*880d7978SAlexander Pyhalov       0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46,
666*880d7978SAlexander Pyhalov 0x47, 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e,
667*880d7978SAlexander Pyhalov 0x4f, 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56,
668*880d7978SAlexander Pyhalov 0x57, 0x58, 0x59, 0x5a, 0x5b, 0x5c, 0x5d, 0x5e,
669*880d7978SAlexander Pyhalov 0x5f, 0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66,
670*880d7978SAlexander Pyhalov 0x67, 0x68, 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e,
671*880d7978SAlexander Pyhalov 0x6f, 0x70, 0x71, 0x72, 0x73, 0x74, 0x75, 0x76,
672*880d7978SAlexander Pyhalov 0x77, 0x78, 0x79, 0x7a, 0x7b, 0x7c, 0x7d, 0x7e,
673*880d7978SAlexander Pyhalov /* Index 64TEN - 94TEN in 'odd KU' */
674*880d7978SAlexander Pyhalov 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
675*880d7978SAlexander Pyhalov 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f,
676*880d7978SAlexander Pyhalov 0x90, 0x91, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97,
677*880d7978SAlexander Pyhalov 0x98, 0x99, 0x9a, 0x9b, 0x9c, 0x9d, 0x9e,
678*880d7978SAlexander Pyhalov /* Values never be indexed */
679*880d7978SAlexander Pyhalov                                           0xff,
680*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
681*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
682*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
683*880d7978SAlexander Pyhalov 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
684*880d7978SAlexander Pyhalov 0xff,
685*880d7978SAlexander Pyhalov /* Index 1TEN - 63TEN in 'even KU' */
686*880d7978SAlexander Pyhalov       0x9f, 0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5,
687*880d7978SAlexander Pyhalov 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad,
688*880d7978SAlexander Pyhalov 0xae, 0xaf, 0xb0, 0xb1, 0xb2, 0xb3, 0xb4, 0xb5,
689*880d7978SAlexander Pyhalov 0xb6, 0xb7, 0xb8, 0xb9, 0xba, 0xbb, 0xbc, 0xbd,
690*880d7978SAlexander Pyhalov 0xbe, 0xbf, 0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5,
691*880d7978SAlexander Pyhalov 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd,
692*880d7978SAlexander Pyhalov 0xce, 0xcf, 0xd0, 0xd1, 0xd2, 0xd3, 0xd4, 0xd5,
693*880d7978SAlexander Pyhalov 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xdb, 0xdc, 0xdd,
694*880d7978SAlexander Pyhalov 0xde, 0xdf, 0xe0, 0xe1, 0xe2, 0xe3, 0xe4, 0xe5,
695*880d7978SAlexander Pyhalov 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xeb, 0xec, 0xed,
696*880d7978SAlexander Pyhalov 0xee, 0xef, 0xf0, 0xf1, 0xf2, 0xf3, 0xf4, 0xf5,
697*880d7978SAlexander Pyhalov 0xf6, 0xf7, 0xf8, 0xf9, 0xfa, 0xfb, 0xfc,
698*880d7978SAlexander Pyhalov /* Values never be indexed */
699*880d7978SAlexander Pyhalov 0xff
700*880d7978SAlexander Pyhalov };
701*880d7978SAlexander Pyhalov 
702*880d7978SAlexander Pyhalov #define	JGETA	(0x222e)
703*880d7978SAlexander Pyhalov #define	EGETA	(0xa2ae)
704*880d7978SAlexander Pyhalov #define	PGETA	(0x81ac)
705*880d7978SAlexander Pyhalov 
706*880d7978SAlexander Pyhalov /*
707*880d7978SAlexander Pyhalov  * Remap NEC/IBM codes to IBM codes
708*880d7978SAlexander Pyhalov  * if dest == 0xffff, that means the source
709*880d7978SAlexander Pyhalov  * code point is illegal in the current spec.
710*880d7978SAlexander Pyhalov  */
711*880d7978SAlexander Pyhalov 
712*880d7978SAlexander Pyhalov  #define REMAP_NEC(dest) \
713*880d7978SAlexander Pyhalov 	if ((0xed40 <= dest) && \
714*880d7978SAlexander Pyhalov 		(dest <= 0xed62)) { \
715*880d7978SAlexander Pyhalov 		dest += 0xd1c; \
716*880d7978SAlexander Pyhalov 	} else if ((0xed63 <= dest) && \
717*880d7978SAlexander Pyhalov 		(dest <= 0xed7e)) { \
718*880d7978SAlexander Pyhalov 		dest += 0xd1d; \
719*880d7978SAlexander Pyhalov 	} else if ((0xed80 <= dest) && \
720*880d7978SAlexander Pyhalov 		(dest <= 0xede0)) { \
721*880d7978SAlexander Pyhalov 		dest += 0xd1c; \
722*880d7978SAlexander Pyhalov 	} else if ((0xede1 <= dest) && \
723*880d7978SAlexander Pyhalov 		(dest <= 0xedfc)) { \
724*880d7978SAlexander Pyhalov 		dest += 0xd5f; \
725*880d7978SAlexander Pyhalov 	} else if ((0xee40 <= dest) && \
726*880d7978SAlexander Pyhalov 		(dest <= 0xee62)) { \
727*880d7978SAlexander Pyhalov 		dest += 0xd1c; \
728*880d7978SAlexander Pyhalov 	} else if ((0xee63 <= dest) && \
729*880d7978SAlexander Pyhalov 		(dest <= 0xee7e)) { \
730*880d7978SAlexander Pyhalov 		dest += 0xd1d; \
731*880d7978SAlexander Pyhalov 	} else if ((0xee80 <= dest) && \
732*880d7978SAlexander Pyhalov 		(dest <= 0xeee0)) { \
733*880d7978SAlexander Pyhalov 		dest += 0xd1c; \
734*880d7978SAlexander Pyhalov 	} else if ((0xeee1 <= dest) && \
735*880d7978SAlexander Pyhalov 		(dest <= 0xeeec)) { \
736*880d7978SAlexander Pyhalov 		dest += 0xd5f; \
737*880d7978SAlexander Pyhalov 	} else if ((0xeeef <= dest) && \
738*880d7978SAlexander Pyhalov 		(dest <= 0xeef8)) { \
739*880d7978SAlexander Pyhalov 		dest += 0xb51; \
740*880d7978SAlexander Pyhalov 	} else if ((0xeef9 <= dest) && \
741*880d7978SAlexander Pyhalov 		(dest <= 0xeefc)) { \
742*880d7978SAlexander Pyhalov 		dest += 0xb5b; \
743*880d7978SAlexander Pyhalov 	} else { \
744*880d7978SAlexander Pyhalov 		dest = 0xffff; \
745*880d7978SAlexander Pyhalov 	}
746*880d7978SAlexander Pyhalov 
747*880d7978SAlexander Pyhalov #define CHECK2BIG(width,time) \
748*880d7978SAlexander Pyhalov 	if (oleft < (width)) { \
749*880d7978SAlexander Pyhalov 		int i; \
750*880d7978SAlexander Pyhalov 		for (i = time; i > 0; i--) { \
751*880d7978SAlexander Pyhalov 			UNGET(); \
752*880d7978SAlexander Pyhalov 		} \
753*880d7978SAlexander Pyhalov 		errno = E2BIG; \
754*880d7978SAlexander Pyhalov 		retval = (size_t)ERR_RETURN; \
755*880d7978SAlexander Pyhalov 		goto ret; \
756*880d7978SAlexander Pyhalov 	}
757*880d7978SAlexander Pyhalov 
758*880d7978SAlexander Pyhalov /*
759*880d7978SAlexander Pyhalov  * halfkana2zenkakuj[]:
760*880d7978SAlexander Pyhalov  * Directly convert JIS X 0201 Kana (half width) to JIS X 0208
761*880d7978SAlexander Pyhalov  * Kana (full width).
762*880d7978SAlexander Pyhalov  * This table is for ISO-2022-JP.RFC1468 mode.
763*880d7978SAlexander Pyhalov  *
764*880d7978SAlexander Pyhalov  * Principal:
765*880d7978SAlexander Pyhalov  * 1: Subtract 0x21 or 0x81.
766*880d7978SAlexander Pyhalov  * 2: Index the array by using the value above as index number.
767*880d7978SAlexander Pyhalov  *
768*880d7978SAlexander Pyhalov  * Note:
769*880d7978SAlexander Pyhalov  */
770*880d7978SAlexander Pyhalov static const unsigned short halfkana2zenkakuj[] = {
771*880d7978SAlexander Pyhalov 0x2123, 0x2156, 0x2157, 0x2122, 0x2126, 0x2572, 0x2521, 0x2523,
772*880d7978SAlexander Pyhalov 0x2525, 0x2527, 0x2529, 0x2563, 0x2565, 0x2567, 0x2543, 0x213c,
773*880d7978SAlexander Pyhalov 0x2522, 0x2524, 0x2526, 0x2528, 0x252a, 0x252b, 0x252d, 0x252f,
774*880d7978SAlexander Pyhalov 0x2531, 0x2533, 0x2535, 0x2537, 0x2539, 0x253b, 0x253d, 0x253f,
775*880d7978SAlexander Pyhalov 0x2541, 0x2544, 0x2546, 0x2548, 0x254a, 0x254b, 0x254c, 0x254d,
776*880d7978SAlexander Pyhalov 0x254e, 0x254f, 0x2552, 0x2555, 0x2558, 0x255b, 0x255e, 0x255f,
777*880d7978SAlexander Pyhalov 0x2560, 0x2561, 0x2562, 0x2564, 0x2566, 0x2568, 0x2569, 0x256a,
778*880d7978SAlexander Pyhalov 0x256b, 0x256c, 0x256d, 0x256f, 0x2573, 0x212b, 0x212c};
779*880d7978SAlexander Pyhalov 
780*880d7978SAlexander Pyhalov /*
781*880d7978SAlexander Pyhalov  * halfkana2zenkakue[]:
782*880d7978SAlexander Pyhalov  * Directly convert JIS X 0201 Kana (half width) to JIS X 0208
783*880d7978SAlexander Pyhalov  * (eucJP).
784*880d7978SAlexander Pyhalov  * This table is for ISO-2022-JP.RFC1468 mode.
785*880d7978SAlexander Pyhalov  *
786*880d7978SAlexander Pyhalov  * Principal:
787*880d7978SAlexander Pyhalov  * 1: Subtract 0x21 or 0x81.
788*880d7978SAlexander Pyhalov  * 2: Index the array by using the value above as index number.
789*880d7978SAlexander Pyhalov  *
790*880d7978SAlexander Pyhalov  * Note:
791*880d7978SAlexander Pyhalov  */
792*880d7978SAlexander Pyhalov static const unsigned short halfkana2zenkakue[] = {
793*880d7978SAlexander Pyhalov 0xa1a3, 0xa1d6, 0xa1d7, 0xa1a2, 0xa1a6, 0xa5f2, 0xa5a1,
794*880d7978SAlexander Pyhalov 0xa5a3, 0xa5a5, 0xa5a7, 0xa5a9, 0xa5e3, 0xa5e5, 0xa5e7,
795*880d7978SAlexander Pyhalov 0xa5c3, 0xa1bc, 0xa5a2, 0xa5a4, 0xa5a6, 0xa5a8, 0xa5aa,
796*880d7978SAlexander Pyhalov 0xa5ab, 0xa5ad, 0xa5af, 0xa5b1, 0xa5b3, 0xa5b5, 0xa5b7,
797*880d7978SAlexander Pyhalov 0xa5b9, 0xa5bb, 0xa5bd, 0xa5bf, 0xa5c1, 0xa5c4, 0xa5c6,
798*880d7978SAlexander Pyhalov 0xa5c8, 0xa5ca, 0xa5cb, 0xa5cc, 0xa5cd, 0xa5ce, 0xa5cf,
799*880d7978SAlexander Pyhalov 0xa5d2, 0xa5d5, 0xa5d8, 0xa5db, 0xa5de, 0xa5df, 0xa5e0,
800*880d7978SAlexander Pyhalov 0xa5e1, 0xa5e2, 0xa5e4, 0xa5e6, 0xa5e8, 0xa5e9, 0xa5ea,
801*880d7978SAlexander Pyhalov 0xa5eb, 0xa5ec, 0xa5ed, 0xa5ef, 0xa5f3, 0xa1ab, 0xa1ac};
802*880d7978SAlexander Pyhalov 
803*880d7978SAlexander Pyhalov /*
804*880d7978SAlexander Pyhalov  * halfkana2zenkakus[]:
805*880d7978SAlexander Pyhalov  * Directly convert JIS X 0201 Kana (half width) to PCK Kana
806*880d7978SAlexander Pyhalov  * (full width).
807*880d7978SAlexander Pyhalov  * This table is for ISO-2022-JP.RFC1468 mode.
808*880d7978SAlexander Pyhalov  *
809*880d7978SAlexander Pyhalov  * Principal:
810*880d7978SAlexander Pyhalov  * 1: Subtract 0x21 or 0x81.
811*880d7978SAlexander Pyhalov  * 2: Index the array by using the value above as index number.
812*880d7978SAlexander Pyhalov  *
813*880d7978SAlexander Pyhalov  * Note:
814*880d7978SAlexander Pyhalov  */
815*880d7978SAlexander Pyhalov static const unsigned short halfkana2zenkakus[] = {
816*880d7978SAlexander Pyhalov 0x8142, 0x8175, 0x8176, 0x8141, 0x8145, 0x8392, 0x8340, 0x8342,
817*880d7978SAlexander Pyhalov 0x8344, 0x8346, 0x8348, 0x8383, 0x8385, 0x8387, 0x8362, 0x815b,
818*880d7978SAlexander Pyhalov 0x8341, 0x8343, 0x8345, 0x8347, 0x8349, 0x834a, 0x834c, 0x834e,
819*880d7978SAlexander Pyhalov 0x8350, 0x8352, 0x8354, 0x8356, 0x8358, 0x835a, 0x835c, 0x835e,
820*880d7978SAlexander Pyhalov 0x8360, 0x8363, 0x8365, 0x8367, 0x8369, 0x836a, 0x836b, 0x836c,
821*880d7978SAlexander Pyhalov 0x836d, 0x836e, 0x8371, 0x8374, 0x8377, 0x837a, 0x837d, 0x837e,
822*880d7978SAlexander Pyhalov 0x8380, 0x8381, 0x8382, 0x8384, 0x8386, 0x8388, 0x8389, 0x838a,
823*880d7978SAlexander Pyhalov 0x838b, 0x838c, 0x838d, 0x838f, 0x8393, 0x814a, 0x814b};
824