2 * Copyright (C) 1999-2001, 2005, 2007, 2016 Free Software Foundation, Inc.
3 * This file is part of the GNU LIBICONV Library.
5 * The GNU LIBICONV Library is free software; you can redistribute it
6 * and/or modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either version 2.1
8 * of the License, or (at your option) any later version.
10 * The GNU LIBICONV Library is distributed in the hope that it will be
11 * useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with the GNU LIBICONV Library; see the file COPYING.LIB.
17 * If not, see <https://www.gnu.org/licenses/>.
21 * CP949 is EUC-KR, extended with UHC (Unified Hangul Code).
23 * Some variants of CP949 (in JDK, Windows-2000, ICU) also add:
25 * 2. Private area mappings:
28 * 0xC9{A1..FE} U+E000..U+E05D
29 * 0xFE{A1..FE} U+E05E..U+E0BB
31 * We add them too because, although there are backward compatibility problems
32 * when a character from a private area is moved to an official Unicode code
33 * point, they are useful for some people in practice.
40 cp949_mbtowc (conv_t conv
, ucs4_t
*pwc
, const unsigned char *s
, size_t n
)
43 /* Code set 0 (ASCII) */
45 return ascii_mbtowc(conv
,pwc
,s
,n
);
47 if (c
>= 0x81 && c
<= 0xa0)
48 return uhc_1_mbtowc(conv
,pwc
,s
,n
);
49 if (c
>= 0xa1 && c
< 0xff) {
53 unsigned char c2
= s
[1];
56 return uhc_2_mbtowc(conv
,pwc
,s
,n
);
57 else if (c2
< 0xff && !(c
== 0xa2 && c2
== 0xe8)) {
58 /* Code set 1 (KS C 5601-1992, now KS X 1001:1998) */
61 buf
[0] = c
-0x80; buf
[1] = c2
-0x80;
62 ret
= ksc5601_mbtowc(conv
,pwc
,buf
,2);
65 /* User-defined characters */
67 *pwc
= 0xe000 + (c2
- 0xa1);
71 *pwc
= 0xe05e + (c2
- 0xa1);
81 cp949_wctomb (conv_t conv
, unsigned char *r
, ucs4_t wc
, size_t n
)
86 /* Code set 0 (ASCII) */
87 ret
= ascii_wctomb(conv
,r
,wc
,n
);
91 /* Code set 1 (KS C 5601-1992, now KS X 1001:1998) */
93 ret
= ksc5601_wctomb(conv
,buf
,wc
,2);
94 if (ret
!= RET_ILUNI
) {
95 if (ret
!= 2) abort();
105 if (wc
>= 0xac00 && wc
< 0xd7a4) {
107 return uhc_1_wctomb(conv
,r
,wc
,n
);
109 return uhc_2_wctomb(conv
,r
,wc
,n
);
112 /* User-defined characters */
113 if (wc
>= 0xe000 && wc
< 0xe0bc) {
118 r
[1] = wc
- 0xe000 + 0xa1;
121 r
[1] = wc
- 0xe05e + 0xa1;