diff options
author | Ulrich Drepper <drepper@redhat.com> | 1999-12-28 04:21:29 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 1999-12-28 04:21:29 +0000 |
commit | dcc203308fa9fccce744640f170896f9747e6732 (patch) | |
tree | a6a7edd6d9d3660b1245576cc2d3d0622468ae4a /iconvdata/gbk.c | |
parent | ffa156afcc46a0b8688a0094e62bc240b4b279a1 (diff) | |
download | glibc-dcc203308fa9fccce744640f170896f9747e6732.tar.gz glibc-dcc203308fa9fccce744640f170896f9747e6732.tar.xz glibc-dcc203308fa9fccce744640f170896f9747e6732.zip |
Update.
* iconvdata/gbk.c: In mapping from UCS4: don't crash for undefined mappings. Fix last patch. * iconvdata/TESTS: Add GBK. * iconvdata/testdata/GBK: New file.
Diffstat (limited to 'iconvdata/gbk.c')
-rw-r--r-- | iconvdata/gbk.c | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/iconvdata/gbk.c b/iconvdata/gbk.c index b468701074..45bfcbcada 100644 --- a/iconvdata/gbk.c +++ b/iconvdata/gbk.c @@ -5549,7 +5549,7 @@ static const char __gbk_from_ucs4_tab1[][2] = [0x0044] = "\xa8\xa8", [0x0045] = "\xa8\xa6", [0x0046] = "\xa8\xba", [0x0048] = "\xa8\xac", [0x0049] = "\xa8\xaa", [0x004e] = "\xa8\xb0", [0x004f] = "\xa8\xae", [0x0053] = "\xa1\xc2", [0x0055] = "\xa8\xb4", - [0x0056] = "\xa8\xb2", [0x0058] = "\xa8\xb9", + [0x0056] = "\xa8\xb2", [0x0058] = "\xa8\xb9", [0x005d] = "\xa8\xa1" }; /* The table can be created using @@ -13190,12 +13190,9 @@ static const char __gbk_from_ucs4_tab12[][2] = { \ switch (ch) \ { \ - case 0xa4 ... 0x100: \ + case 0xa4 ... 0x101: \ cp = __gbk_from_ucs4_tab1[ch - 0xa4]; \ break; \ - case 0x101: \ - cp = "\xa8\xa1"; \ - break; \ case 0x113: \ cp = "\xa8\xa5"; \ break; \ @@ -13248,7 +13245,7 @@ static const char __gbk_from_ucs4_tab12[][2] = cp = "\xa8\xc0"; \ break; \ case 0x2c7 ... 0x2cb: \ - cp = "\xa1\xa6\0\0\0\0\0\0\xa1\xa5\0\0\xa8\x40\0\0\xa8\x41"[(ch - 0x2c7) * 4]; \ + cp = "\xa1\xa6\0\0\0\0\0\0\xa1\xa5\0\0\xa8\x40\0\0\xa8\x41" + ((ch - 0x2c7) * 4); \ break; \ case 0x2d9: \ cp = "\xa8\x42"; \ @@ -13288,7 +13285,7 @@ static const char __gbk_from_ucs4_tab12[][2] = buf[1] = '\x80' + (ch - 0x2588); \ break; \ case 0x2593 ... 0x2595: \ - cp = "\xa8\x88\0\0\xa8\x89\0\0\xa8\x8a"[(ch - 0x2593) * 4]; \ + cp = "\xa8\x88\0\0\xa8\x89\0\0\xa8\x8a" + ((ch - 0x2593) * 4); \ break; \ case 0x25a0: \ cp = "\xa1\xf6"; \ @@ -13419,13 +13416,13 @@ static const char __gbk_from_ucs4_tab12[][2] = cp = __gbk_from_ucs4_tab12[ch - 0xff01]; \ break; \ case 0xffe0 ... 0xffe5: \ - cp = "\xa1\xe9\0\0\xa1\xea\0\0\xa9\x56\0\0\xa3\xfe\0\0\xa9\x57\0\0\xa3\xa4"[(ch - 0xffe0) * 4]; \ + cp = "\xa1\xe9\0\0\xa1\xea\0\0\xa9\x56\0\0\xa3\xfe\0\0\xa9\x57\0\0\xa3\xa4" + ((ch - 0xffe0) * 4); \ break; \ default: \ cp = ""; \ break; \ } \ - if (cp[0] == '\0' && ch != 0) \ + if (cp == NULL || (cp[0] == '\0' && ch != 0)) \ { \ /* Illegal character. */ \ result = __GCONV_ILLEGAL_INPUT; \ |