1*16d86563SAlexander Pyhalov /*
2*16d86563SAlexander Pyhalov  * CDDL HEADER START
3*16d86563SAlexander Pyhalov  *
4*16d86563SAlexander Pyhalov  * The contents of this file are subject to the terms of the
5*16d86563SAlexander Pyhalov  * Common Development and Distribution License (the "License").
6*16d86563SAlexander Pyhalov  * You may not use this file except in compliance with the License.
7*16d86563SAlexander Pyhalov  *
8*16d86563SAlexander Pyhalov  * You can obtain a copy of the license at src/OPENSOLARIS.LICENSE
9*16d86563SAlexander Pyhalov  * or http://www.opensolaris.org/os/licensing.
10*16d86563SAlexander Pyhalov  * See the License for the specific language governing permissions
11*16d86563SAlexander Pyhalov  * and limitations under the License.
12*16d86563SAlexander Pyhalov  *
13*16d86563SAlexander Pyhalov  * When distributing Covered Code, include this CDDL HEADER in each
14*16d86563SAlexander Pyhalov  * file and include the License file at src/OPENSOLARIS.LICENSE.
15*16d86563SAlexander Pyhalov  * If applicable, add the following below this CDDL HEADER, with the
16*16d86563SAlexander Pyhalov  * fields enclosed by brackets "[]" replaced with your own identifying
17*16d86563SAlexander Pyhalov  * information: Portions Copyright [yyyy] [name of copyright owner]
18*16d86563SAlexander Pyhalov  *
19*16d86563SAlexander Pyhalov  * CDDL HEADER END
20*16d86563SAlexander Pyhalov  */
21*16d86563SAlexander Pyhalov /*
22*16d86563SAlexander Pyhalov  * Copyright (c) 1996 by Sun Microsystems, Inc.
23*16d86563SAlexander Pyhalov  */
24*16d86563SAlexander Pyhalov 
25*16d86563SAlexander Pyhalov 
26*16d86563SAlexander Pyhalov #include <errno.h>
27*16d86563SAlexander Pyhalov #include <stdlib.h>
28*16d86563SAlexander Pyhalov #include "common_han.h"
29*16d86563SAlexander Pyhalov #include "common_utf.h"
30*16d86563SAlexander Pyhalov #include "common_njh.h"
31*16d86563SAlexander Pyhalov #include "utf_njh_table.h"
32*16d86563SAlexander Pyhalov 
node_compare(const void * node1,const void * node2)33*16d86563SAlexander Pyhalov static int node_compare(const void *node1, const void *node2)
34*16d86563SAlexander Pyhalov {
35*16d86563SAlexander Pyhalov 	return((int)(((const hcode_table *)node1)->utf8.code) -
36*16d86563SAlexander Pyhalov 	       (int)(((const hcode_table *)node2)->utf8.code));
37*16d86563SAlexander Pyhalov }
38*16d86563SAlexander Pyhalov 
39*16d86563SAlexander Pyhalov 
40*16d86563SAlexander Pyhalov /****  _ U T F 8 _ T O _ J O H A P 9 2 ****/
41*16d86563SAlexander Pyhalov 
_utf8_to_johap92(hcode_type utfcode)42*16d86563SAlexander Pyhalov hcode_type _utf8_to_johap92(hcode_type utfcode)
43*16d86563SAlexander Pyhalov {
44*16d86563SAlexander Pyhalov         hcode_table *node_ptr, node;
45*16d86563SAlexander Pyhalov 	hcode_type johap, unicode;
46*16d86563SAlexander Pyhalov 	int udc_index;
47*16d86563SAlexander Pyhalov 
48*16d86563SAlexander Pyhalov 	/* User Definable Area Check */
49*16d86563SAlexander Pyhalov 	if ((udc_index = _utf_to_udcidx(utfcode)) != IDX_UDC_ERROR) {
50*16d86563SAlexander Pyhalov 
51*16d86563SAlexander Pyhalov 		johap.byte.byte3 = NJH_UDC_SEG;
52*16d86563SAlexander Pyhalov 
53*16d86563SAlexander Pyhalov 		if (udc_index < NJH_UDC_OFFSET_GAP)
54*16d86563SAlexander Pyhalov 			johap.byte.byte4 = (unsigned int)(udc_index +
55*16d86563SAlexander Pyhalov 						NJH_UDC_OFFSET1_START);
56*16d86563SAlexander Pyhalov 		else
57*16d86563SAlexander Pyhalov 			johap.byte.byte4 = NJH_UDC_OFFSET2_START +
58*16d86563SAlexander Pyhalov 				(unsigned int)(udc_index - NJH_UDC_OFFSET_GAP);
59*16d86563SAlexander Pyhalov 
60*16d86563SAlexander Pyhalov 		return(johap);
61*16d86563SAlexander Pyhalov 	}
62*16d86563SAlexander Pyhalov 
63*16d86563SAlexander Pyhalov 	unicode = _utf8_to_uni(utfcode);
64*16d86563SAlexander Pyhalov 
65*16d86563SAlexander Pyhalov 	if ((UNICODE_HANGUL_START <= unicode.code) &&
66*16d86563SAlexander Pyhalov 	    (unicode.code <= UNICODE_HANGUL_END)) {
67*16d86563SAlexander Pyhalov 		/* Hangul Area */
68*16d86563SAlexander Pyhalov 		unsigned int uni, x, y, z;
69*16d86563SAlexander Pyhalov 
70*16d86563SAlexander Pyhalov 		uni  = unicode.code - 0xAC00;
71*16d86563SAlexander Pyhalov 		x = uni / 588;
72*16d86563SAlexander Pyhalov 			/* 588 = 21(Joongsung Number) * 28(Jongsung Number) */
73*16d86563SAlexander Pyhalov 		y = (uni % 588) / 28;
74*16d86563SAlexander Pyhalov 		z = (uni % 588) % 28;
75*16d86563SAlexander Pyhalov 		z = z > 0x10 ? z + 2 : z + 1;
76*16d86563SAlexander Pyhalov 
77*16d86563SAlexander Pyhalov 		johap.code = 0;
78*16d86563SAlexander Pyhalov 		johap.johap.msb = 1;
79*16d86563SAlexander Pyhalov 		johap.johap.jongsung = z;
80*16d86563SAlexander Pyhalov 		johap.johap.joongsung = y > 0x10 ? y + 9 :
81*16d86563SAlexander Pyhalov 			y > 0x0A ? y + 7 :
82*16d86563SAlexander Pyhalov 			y > 0x04 ? y + 5 : y + 3;
83*16d86563SAlexander Pyhalov 		johap.johap.chosung = x + 2;
84*16d86563SAlexander Pyhalov 
85*16d86563SAlexander Pyhalov 		return(johap);
86*16d86563SAlexander Pyhalov 
87*16d86563SAlexander Pyhalov 	} else {
88*16d86563SAlexander Pyhalov 		/* Notes: if need hangul jamo later, add here */
89*16d86563SAlexander Pyhalov 
90*16d86563SAlexander Pyhalov 	        node.utf8 = utfcode;
91*16d86563SAlexander Pyhalov 
92*16d86563SAlexander Pyhalov 		node_ptr = bsearch( &node,
93*16d86563SAlexander Pyhalov 			utf2njh_tbl, sizeof(utf2njh_tbl)/sizeof(hcode_table),
94*16d86563SAlexander Pyhalov 			sizeof(hcode_table), node_compare);
95*16d86563SAlexander Pyhalov 
96*16d86563SAlexander Pyhalov 		johap.code = NON_ID_CHAR; /* initial & default set to fail value */
97*16d86563SAlexander Pyhalov 
98*16d86563SAlexander Pyhalov 		if (node_ptr != NULL)
99*16d86563SAlexander Pyhalov 			johap.word.low = node_ptr->code; /* Success */
100*16d86563SAlexander Pyhalov 
101*16d86563SAlexander Pyhalov 		return(johap);
102*16d86563SAlexander Pyhalov 	}
103*16d86563SAlexander Pyhalov 
104*16d86563SAlexander Pyhalov 
105*16d86563SAlexander Pyhalov }  /* end of hcode_type _utf8_to_johap92(hcode_type utfcode) */
106