aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--iconvdata/EUC-KR.irreversible1
-rw-r--r--iconvdata/euc-kr.c28
-rw-r--r--iconvdata/testdata/EUC-KR..UTF82
-rw-r--r--localedata/charmaps/EUC-KR2
-rw-r--r--localedata/locales/ko_KR4
6 files changed, 25 insertions, 17 deletions
diff --git a/ChangeLog b/ChangeLog
index ec30782a0c..7ed6556ab0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
2000-10-04 Ulrich Drepper <drepper@redhat.com>
+ * iconvdata/euc-kr.c (euckr_from_ucs4): Handle U20a9.
+ (BODY from direction): Map \x5c to U20a9.
+ * iconvdata/testdata/EUC-KR..UTF8: Adjust to this change.
+ * iconvdata/EUC-KR.irreversible: New file.
+
* argp/argp-parse.c (argp_default_argp): Set libc as message domain.
(argp_version_argp): Likewise.
diff --git a/iconvdata/EUC-KR.irreversible b/iconvdata/EUC-KR.irreversible
new file mode 100644
index 0000000000..4eadbb376c
--- /dev/null
+++ b/iconvdata/EUC-KR.irreversible
@@ -0,0 +1 @@
+0x5C 0x005C
diff --git a/iconvdata/euc-kr.c b/iconvdata/euc-kr.c
index 9ea937c005..0b4e29abe3 100644
--- a/iconvdata/euc-kr.c
+++ b/iconvdata/euc-kr.c
@@ -29,7 +29,13 @@ euckr_from_ucs4 (uint32_t ch, unsigned char *cp)
{
if (ch > 0x9f)
{
- if (__builtin_expect (ucs4_to_ksc5601 (ch, cp, 2), 0)
+ if (__builtin_expect (ch, 0) == 0x20a9)
+ {
+ /* Half-width Korean Currency WON sign. */
+ cp[0] = '\\';
+ cp[1] = '\0';
+ }
+ else if (__builtin_expect (ucs4_to_ksc5601 (ch, cp, 2), 0)
!= __UNKNOWN_10646_CHAR)
{
cp[0] |= 0x80;
@@ -38,9 +44,10 @@ euckr_from_ucs4 (uint32_t ch, unsigned char *cp)
else
cp[0] = '\0';
}
- /* XXX Think about 0x5c ; '\'. */
else
{
+ /* There is no mapping for U005c but we nevertheless map it to
+ \x5c. */
cp[0] = (unsigned char) ch;
cp[1] = '\0';
}
@@ -67,17 +74,14 @@ euckr_from_ucs4 (uint32_t ch, unsigned char *cp)
{ \
uint32_t ch = *inptr; \
\
- /* Half-width Korean Currency WON sign \
- \
- if (inchar == 0x5c) \
- ch = 0x20a9; \
- else if (inchar <= 0x7f) \
- ch = (uint32_t) inchar; \
- */ \
- \
if (ch <= 0x9f) \
- /* Plain ASCII. */ \
- ++inptr; \
+ { \
+ /* Plain ASCII with one exception. */ \
+ if (ch == 0x5c) \
+ /* Half-width Korean Currency WON sign. */ \
+ ch = 0x20a9; \
+ ++inptr; \
+ } \
/* 0xfe(->0x7e : row 94) and 0xc9(->0x59 : row 41) are \
user-defined areas. */ \
else if (__builtin_expect (ch, 0xa1) == 0xa0 \
diff --git a/iconvdata/testdata/EUC-KR..UTF8 b/iconvdata/testdata/EUC-KR..UTF8
index e287e76c6f..b6c484fa11 100644
--- a/iconvdata/testdata/EUC-KR..UTF8
+++ b/iconvdata/testdata/EUC-KR..UTF8
@@ -1,7 +1,7 @@
! " # $ % & ' ( ) * + , - . /
0 1 2 3 4 5 6 7 8 9 : ; < = > ?
@ A B C D E F G H I J K L M N O
- P Q R S T U V W X Y Z [ \ ] ^ _
+ P Q R S T U V W X Y Z [ ₩ ] ^ _
` a b c d e f g h i j k l m n o
p q r s t u v w x y z { | } ~
diff --git a/localedata/charmaps/EUC-KR b/localedata/charmaps/EUC-KR
index bf18ea6106..6a4326790c 100644
--- a/localedata/charmaps/EUC-KR
+++ b/localedata/charmaps/EUC-KR
@@ -100,7 +100,7 @@ CHARMAP
<U0059> /x59 LATIN CAPITAL LETTER Y
<U005A> /x5a LATIN CAPITAL LETTER Z
<U005B> /x5b LEFT SQUARE BRACKET
-<U005C> /x5c REVERSE SOLIDUS
+<U20A9> /x5c WON SIGN
<U005D> /x5d RIGHT SQUARE BRACKET
<U005E> /x5e CIRCUMFLEX ACCENT
<U005F> /x5f LOW LINE
diff --git a/localedata/locales/ko_KR b/localedata/locales/ko_KR
index cfeeadc1e7..1b9ec128ce 100644
--- a/localedata/locales/ko_KR
+++ b/localedata/locales/ko_KR
@@ -11120,9 +11120,7 @@ END LC_CTYPE
LC_MONETARY
int_curr_symbol "<U004B><U0052><U0057><U0020>"
-% Should be U20A9 but this is not in EUC-KR. Or is it?
-% currency_symbol "<U20A9>"
-currency_symbol "<UFFE6>"
+currency_symbol "<U20A9>"
mon_decimal_point "<U002E>"
mon_thousands_sep "<U002C>"
mon_grouping 3;3