xref: /titanic_50/usr/src/lib/iconv_modules/ko/common/c2p.c (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 /* $Id: c2p.c,v 1.12 1997/10/31 16:16:56 binz Exp $ SMI: ALE */
22*880d7978SAlexander Pyhalov 
23*880d7978SAlexander Pyhalov /*
24*880d7978SAlexander Pyhalov  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
25*880d7978SAlexander Pyhalov  * Use is subject to license terms.
26*880d7978SAlexander Pyhalov  */
27*880d7978SAlexander Pyhalov 
28*880d7978SAlexander Pyhalov /*
29*880d7978SAlexander Pyhalov  *  Convert 2 byte completion  code to
30*880d7978SAlexander Pyhalov  *	    2 byte combination code
31*880d7978SAlexander Pyhalov  *  1) find the sequential No. of initial and middle sounds.
32*880d7978SAlexander Pyhalov  *  2) decide the displacement of final sound from the starting point.
33*880d7978SAlexander Pyhalov  *  3) combine each sounds into combination code.
34*880d7978SAlexander Pyhalov  */
35*880d7978SAlexander Pyhalov 
36*880d7978SAlexander Pyhalov #include 	<stdio.h>
37*880d7978SAlexander Pyhalov #include	"kdefs.h"
38*880d7978SAlexander Pyhalov #include	"ktable.h"
39*880d7978SAlexander Pyhalov 
40*880d7978SAlexander Pyhalov #define		SKIP	0xa1 + 0xff - 0xfe
41*880d7978SAlexander Pyhalov 
42*880d7978SAlexander Pyhalov #define 	CI_CNT  19 - 1
43*880d7978SAlexander Pyhalov #define		V_CNT	21 - 1
44*880d7978SAlexander Pyhalov 
45*880d7978SAlexander Pyhalov /* KS C 5601-1986 */
c2p(comp2)46*880d7978SAlexander Pyhalov KCHAR c2p(comp2)
47*880d7978SAlexander Pyhalov KCHAR comp2;
48*880d7978SAlexander Pyhalov {
49*880d7978SAlexander Pyhalov 
50*880d7978SAlexander Pyhalov 	KCHAR	comb2;
51*880d7978SAlexander Pyhalov 	short 	Ci_val;		/* initial sound */
52*880d7978SAlexander Pyhalov 	short	V_val ;		/* middle  sound */
53*880d7978SAlexander Pyhalov 	short	Cf_val;		/* final   sound */
54*880d7978SAlexander Pyhalov 	short	mask  ;
55*880d7978SAlexander Pyhalov 	short 	high = CI_CNT ;
56*880d7978SAlexander Pyhalov 	short	low  = 0      ;
57*880d7978SAlexander Pyhalov 
58*880d7978SAlexander Pyhalov 	int	disp,cnt;
59*880d7978SAlexander Pyhalov 
60*880d7978SAlexander Pyhalov 	long	Cfbit ;
61*880d7978SAlexander Pyhalov 
62*880d7978SAlexander Pyhalov /*
63*880d7978SAlexander Pyhalov  * Find initial sound (Ci_val) and
64*880d7978SAlexander Pyhalov  *	middle  sound (V_val )
65*880d7978SAlexander Pyhalov  * which make the starting point for 'comp2'.
66*880d7978SAlexander Pyhalov  */
67*880d7978SAlexander Pyhalov 
68*880d7978SAlexander Pyhalov 	for (;;) {
69*880d7978SAlexander Pyhalov 		Ci_val = (low + high) / 2 ;
70*880d7978SAlexander Pyhalov 		if (low >= high)
71*880d7978SAlexander Pyhalov 			break ;
72*880d7978SAlexander Pyhalov 		if (comp2 < cmp_srchtbl[Ci_val][0])
73*880d7978SAlexander Pyhalov 			high = Ci_val - 1 ;
74*880d7978SAlexander Pyhalov 		else if (comp2 < cmp_srchtbl[Ci_val+1][0])
75*880d7978SAlexander Pyhalov 			break ;
76*880d7978SAlexander Pyhalov 		     else low = Ci_val + 1 ;
77*880d7978SAlexander Pyhalov 	}
78*880d7978SAlexander Pyhalov 
79*880d7978SAlexander Pyhalov 	V_val = 1;
80*880d7978SAlexander Pyhalov 	while(1) {
81*880d7978SAlexander Pyhalov 		if (comp2 < cmp_srchtbl[Ci_val][V_val]) {
82*880d7978SAlexander Pyhalov 			while(cmp_srchtbl[Ci_val][--V_val] == 0)
83*880d7978SAlexander Pyhalov 				;
84*880d7978SAlexander Pyhalov 			break;
85*880d7978SAlexander Pyhalov 		}else if (V_val == V_CNT)
86*880d7978SAlexander Pyhalov 			break ;
87*880d7978SAlexander Pyhalov 		V_val++;
88*880d7978SAlexander Pyhalov 	}
89*880d7978SAlexander Pyhalov 
90*880d7978SAlexander Pyhalov 	/* Find displacement (temporary final sound value) */
91*880d7978SAlexander Pyhalov 
92*880d7978SAlexander Pyhalov 	disp  = comp2 - cmp_srchtbl[Ci_val][V_val] ;
93*880d7978SAlexander Pyhalov 	mask  = cmp_srchtbl[Ci_val][V_val] & BYTE_MASK  ;
94*880d7978SAlexander Pyhalov 
95*880d7978SAlexander Pyhalov 	if ((mask + disp) > 0xfe)
96*880d7978SAlexander Pyhalov 		disp -= SKIP ;
97*880d7978SAlexander Pyhalov 
98*880d7978SAlexander Pyhalov 	/* Find the value of final sound */
99*880d7978SAlexander Pyhalov 
100*880d7978SAlexander Pyhalov 	Cfbit = cmp_bitmap[Ci_val][V_val] ;
101*880d7978SAlexander Pyhalov 	for (cnt = -1 , Cf_val = -1; cnt < disp; Cf_val++)
102*880d7978SAlexander Pyhalov 		{
103*880d7978SAlexander Pyhalov 			if (Cfbit & BIT_MASK)
104*880d7978SAlexander Pyhalov 				cnt++ ;
105*880d7978SAlexander Pyhalov 			Cfbit >>= 1   ;
106*880d7978SAlexander Pyhalov 		}
107*880d7978SAlexander Pyhalov 
108*880d7978SAlexander Pyhalov 	/* make 2 byte combination code	*/
109*880d7978SAlexander Pyhalov 
110*880d7978SAlexander Pyhalov 	comb2  = (unsigned int) (Ci_val + 0x0a) ;
111*880d7978SAlexander Pyhalov 	comb2  = (comb2 << 5) | (V_val + (V_val + 1)/3 + 2) ;
112*880d7978SAlexander Pyhalov 	comb2  = (comb2 << 5) | Cf_val ;
113*880d7978SAlexander Pyhalov 
114*880d7978SAlexander Pyhalov 	return(comb2 | 0x8000) ;
115*880d7978SAlexander Pyhalov }
116*880d7978SAlexander Pyhalov 
117*880d7978SAlexander Pyhalov /* KS C 5601-1992 */
c2j(comp2)118*880d7978SAlexander Pyhalov KCHAR c2j(comp2)
119*880d7978SAlexander Pyhalov KCHAR comp2;
120*880d7978SAlexander Pyhalov {
121*880d7978SAlexander Pyhalov 
122*880d7978SAlexander Pyhalov 	KCHAR	comb2;
123*880d7978SAlexander Pyhalov 	short 	Ci_val;		/* initial sound */
124*880d7978SAlexander Pyhalov 	short	V_val ;		/* middle  sound */
125*880d7978SAlexander Pyhalov 	short	Cf_val;		/* final   sound */
126*880d7978SAlexander Pyhalov 	short	mask  ;
127*880d7978SAlexander Pyhalov 	short 	high = CI_CNT ;
128*880d7978SAlexander Pyhalov 	short	low  = 0      ;
129*880d7978SAlexander Pyhalov 
130*880d7978SAlexander Pyhalov 	int	disp,cnt;
131*880d7978SAlexander Pyhalov 
132*880d7978SAlexander Pyhalov 	long	Cfbit ;
133*880d7978SAlexander Pyhalov 
134*880d7978SAlexander Pyhalov /*
135*880d7978SAlexander Pyhalov  * Find initial sound (Ci_val) and
136*880d7978SAlexander Pyhalov  *	middle  sound (V_val )
137*880d7978SAlexander Pyhalov  * which make the starting point for 'comp2'.
138*880d7978SAlexander Pyhalov  */
139*880d7978SAlexander Pyhalov 
140*880d7978SAlexander Pyhalov 	for (;;) {
141*880d7978SAlexander Pyhalov 		Ci_val = (low + high) / 2 ;
142*880d7978SAlexander Pyhalov 		if (low >= high)
143*880d7978SAlexander Pyhalov 			break ;
144*880d7978SAlexander Pyhalov 		if (comp2 < cmp_srchtbl[Ci_val][0])
145*880d7978SAlexander Pyhalov 			high = Ci_val - 1 ;
146*880d7978SAlexander Pyhalov 		else if (comp2 < cmp_srchtbl[Ci_val+1][0])
147*880d7978SAlexander Pyhalov 			break ;
148*880d7978SAlexander Pyhalov 		     else low = Ci_val + 1 ;
149*880d7978SAlexander Pyhalov 	}
150*880d7978SAlexander Pyhalov 
151*880d7978SAlexander Pyhalov 	V_val = 1;
152*880d7978SAlexander Pyhalov 	while(1) {
153*880d7978SAlexander Pyhalov 		if (comp2 < cmp_srchtbl[Ci_val][V_val]) {
154*880d7978SAlexander Pyhalov 			while(cmp_srchtbl[Ci_val][--V_val] == 0)
155*880d7978SAlexander Pyhalov 				;
156*880d7978SAlexander Pyhalov 			break;
157*880d7978SAlexander Pyhalov 		}else if (V_val == V_CNT)
158*880d7978SAlexander Pyhalov 			break ;
159*880d7978SAlexander Pyhalov 		V_val++;
160*880d7978SAlexander Pyhalov 	}
161*880d7978SAlexander Pyhalov 
162*880d7978SAlexander Pyhalov 	/* Find displacement (temporary final sound value) */
163*880d7978SAlexander Pyhalov 
164*880d7978SAlexander Pyhalov 	disp  = comp2 - cmp_srchtbl[Ci_val][V_val] ;
165*880d7978SAlexander Pyhalov 	mask  = cmp_srchtbl[Ci_val][V_val] & BYTE_MASK  ;
166*880d7978SAlexander Pyhalov 
167*880d7978SAlexander Pyhalov 	if ((mask + disp) > 0xfe)
168*880d7978SAlexander Pyhalov 		disp -= SKIP ;
169*880d7978SAlexander Pyhalov 
170*880d7978SAlexander Pyhalov 	/* Find the value of final sound */
171*880d7978SAlexander Pyhalov 
172*880d7978SAlexander Pyhalov 	Cfbit = cmp_bitmap[Ci_val][V_val] ;
173*880d7978SAlexander Pyhalov 	for (cnt = -1 , Cf_val = -1; cnt < disp; Cf_val++)
174*880d7978SAlexander Pyhalov 		{
175*880d7978SAlexander Pyhalov 			if (Cfbit & BIT_MASK)
176*880d7978SAlexander Pyhalov 				cnt++ ;
177*880d7978SAlexander Pyhalov 			Cfbit >>= 1   ;
178*880d7978SAlexander Pyhalov 		}
179*880d7978SAlexander Pyhalov 
180*880d7978SAlexander Pyhalov 	/* make 2 byte combination code	*/
181*880d7978SAlexander Pyhalov 
182*880d7978SAlexander Pyhalov 	comb2 = (unsigned int) (Ci_val + 2);
183*880d7978SAlexander Pyhalov 	comb2 = (comb2 << 5) | (V_val + (V_val + 1) / 6 * 2 + 3);
184*880d7978SAlexander Pyhalov 	comb2 = (comb2 << 5) | (Cf_val + (Cf_val) / 18);
185*880d7978SAlexander Pyhalov 
186*880d7978SAlexander Pyhalov 
187*880d7978SAlexander Pyhalov 	return(comb2 | 0x8000) ;
188*880d7978SAlexander Pyhalov }
189*880d7978SAlexander Pyhalov 
190*880d7978SAlexander Pyhalov #ifdef TESTPRINT
main()191*880d7978SAlexander Pyhalov main()
192*880d7978SAlexander Pyhalov {
193*880d7978SAlexander Pyhalov 	unsigned short comp2, comb2;
194*880d7978SAlexander Pyhalov 	int i,j;
195*880d7978SAlexander Pyhalov 
196*880d7978SAlexander Pyhalov 	printf("\ncompletion code       combination code\n");
197*880d7978SAlexander Pyhalov 	for (i=0xb0;i<=0xc8;i++) {
198*880d7978SAlexander Pyhalov 		for (j=0xa1;j<=0xfe;j++) {
199*880d7978SAlexander Pyhalov 			comp2 = i<<8|j;
200*880d7978SAlexander Pyhalov 			comb2 = comptopack(comp2);
201*880d7978SAlexander Pyhalov 			printf("    %4x                        %4x\n", comp2,comb2);
202*880d7978SAlexander Pyhalov 		}
203*880d7978SAlexander Pyhalov 	}
204*880d7978SAlexander Pyhalov }
205*880d7978SAlexander Pyhalov #endif
206