about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog48
-rw-r--r--iconvdata/Makefile2
-rw-r--r--iconvdata/ansi_x3.110.c23
-rw-r--r--iconvdata/isiri-3342.c4
-rw-r--r--iconvdata/isiri-3342.h325
-rw-r--r--iconvdata/iso_6937.c11
-rw-r--r--iconvdata/johab.c13
-rw-r--r--iconvdata/macintosh.c4
-rw-r--r--iconvdata/sjis.c3
-rw-r--r--iconvdata/t.61.c14
-rw-r--r--iconvdata/uhc.c5
-rw-r--r--string/strxfrm.c19
12 files changed, 422 insertions, 49 deletions
diff --git a/ChangeLog b/ChangeLog
index e6f800d718..c117eebed3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,51 @@
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/sjis.c (BODY for FROM_LOOP): Treat the case
+	ch >= 0x81 && ch2 < 0x40 as invalid.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/uhc.c (BODY for FROM_LOOP): Reject ch2 == 0xff as invalid.
+	(BODY for TO_LOOP): Accept 0x7f. Increment outptr as needed.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/johab.c (BODY for TO_LOOP): After calling
+	ucs4_to_ksc5601_sym, fix the conversion to JOHAB.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/t.61.c (to_ucs4): Change values of 0xa4, 0a6, 0xa8, 0xb4,
+	0xb8.
+	(from_ucs4): Change values of U+00A4, U+00BB, U+00ED.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/macintosh.c (HAS_HOLES): Set to 1.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/iso_6937.c (to_ucs4): Change values of 0x24 and 0xb4.
+	(from_ucs4): Change values of U+00A4 and U+00ED.
+	(BODY of TO_LOOP): Remove mapping from U+02DC to 0x0020.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/ansi_x3.110.c (from_ucs4): Change entry for 0xed.
+	(BODY for TO_LOOP): Map U+2122, U+2126, not U+2022, U+2026.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* iconvdata/Makefile (gen-8bit-gap-modules): Remove isiri-3342.
+	* iconvdata/isiri-3342.h: New file.
+	* iconvdata/isiri-3342.c (HAS_HOLES): Avoid gaps >= 0xe0, but don't
+	treat 0x80 as a gap.
+
+2000-07-30  Bruno Haible  <haible@clisp.cons.org>
+
+	* string/strxfrm.c (encoding_mask, encoding_byte): Remove.
+	(utf8_encode): Use simple shifts instead.  Fix return value.
+
 2000-07-31  Ulrich Drepper  <drepper@redhat.com>
 
 	* timezone/private.h: Update from tzcode2000e.
diff --git a/iconvdata/Makefile b/iconvdata/Makefile
index e7a8dbdd70..914fac30b2 100644
--- a/iconvdata/Makefile
+++ b/iconvdata/Makefile
@@ -159,7 +159,7 @@ gen-8bit-gap-modules := koi8-r latin-greek latin-greek-1 ibm256 ibm273	   \
 			inis-cyrillic iso_2033 iso_5427 iso_5427-ext	   \
 			iso_5428 iso_10367-box mac-is nats-dano nats-sefi  \
 			iso8859-13 iso8859-14 iso8859-15 mac-uk sami-ws2   \
-			iso-ir-197 cp1258 tis-620 koi8-u ibm874 isiri-3342
+			iso-ir-197 cp1258 tis-620 koi8-u ibm874
 
 gen-special-modules := iso8859-7jp
 
diff --git a/iconvdata/ansi_x3.110.c b/iconvdata/ansi_x3.110.c
index d55af6fba7..ed312a0285 100644
--- a/iconvdata/ansi_x3.110.c
+++ b/iconvdata/ansi_x3.110.c
@@ -319,7 +319,7 @@ static const char from_ucs4[][2] =
   /* 0x00dc */ "\xc8\x55", "\xc2\x59", "\xec\x00", "\xfb\x00", "\xc1\x61",
   /* 0x00e1 */ "\xc2\x61", "\xc3\x61", "\xc4\x61", "\xc8\x61", "\xca\x61",
   /* 0x00e6 */ "\xf1\x00", "\xcb\x63", "\xc1\x65", "\xc2\x65", "\xc3\x65",
-  /* 0x00eb */ "\xc8\x65", "\xc1\x69", "\xc2\xe9", "\xc3\x69", "\xc8\x69",
+  /* 0x00eb */ "\xc8\x65", "\xc1\x69", "\xc2\x69", "\xc3\x69", "\xc8\x69",
   /* 0x00f0 */ "\xf3\x00", "\xc4\x6e", "\xc1\x6f", "\xc2\x6f", "\xc3\x6f",
   /* 0x00f5 */ "\xc4\x6f", "\xc8\x6f", "\xb8\x00", "\xf9\x00", "\xc1\x75",
   /* 0x00fa */ "\xc2\x75", "\xc3\x75", "\xc8\x75", "\xc2\x79", "\xfc\x00",
@@ -487,11 +487,10 @@ static const char from_ucs4[][2] =
 	    tmp[1] = ' ';						      \
 	    cp = tmp;							      \
 	  }								      \
-	else if (ch >= 0x2014 && ch <= 0x2026)				      \
+	else if (ch >= 0x2014 && ch <= 0x201d)				      \
 	  {								      \
-	    static const char map[19] =					      \
-	      "\xd0\x00\x00\x00\xa9\xb9\x00\x00\xaa\xba\x00\x00\x00\x00"      \
-	      "\xd4\x00\x00\x00\xe0";					      \
+	    static const char map[10] =					      \
+	      "\xd0\x00\x00\x00\xa9\xb9\x00\x00\xaa\xba";		      \
 									      \
 	    tmp[0] = map[ch - 0x2014];					      \
 	    if (tmp[0] == '\0')						      \
@@ -502,6 +501,20 @@ static const char from_ucs4[][2] =
 	    tmp[1] = '\0';						      \
 	    cp = tmp;							      \
 	  }								      \
+	else if (ch >= 0x2122 && ch <= 0x2126)				      \
+	  {								      \
+	    static const char map[5] =					      \
+	      "\xd4\x00\x00\x00\xe0";					      \
+									      \
+	    tmp[0] = map[ch - 0x2122];					      \
+	    if (tmp[0] == '\0')						      \
+	      {								      \
+		/* Illegal characters.  */				      \
+		STANDARD_ERR_HANDLER (4);				      \
+	      }								      \
+	    tmp[1] = '\0';						      \
+	    cp = tmp;							      \
+	  }								      \
 	else if (ch >= 0x215b && ch <= 0x215e)				      \
 	  {								      \
 	    tmp[0] = 0xdc + ch - 0x215b;				      \
diff --git a/iconvdata/isiri-3342.c b/iconvdata/isiri-3342.c
index 80f7b90d94..f2415bc778 100644
--- a/iconvdata/isiri-3342.c
+++ b/iconvdata/isiri-3342.c
@@ -1,5 +1,5 @@
 /* Conversion from and to ISIRI-3342.
-   Copyright (C) 1999 Free Software Foundation, Inc.
+   Copyright (C) 1999, 2000 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1999.
 
@@ -24,6 +24,6 @@
 #define TABLES <isiri-3342.h>
 
 #define CHARSET_NAME	"ISIRI-3342//"
-#define HAS_HOLES	1	/* Not all 256 character are defined.  */
+#define HAS_HOLES	(*inptr > 0x80)	/* 0x80 really maps to 0x0000.  */
 
 #include <8bit-gap.c>
diff --git a/iconvdata/isiri-3342.h b/iconvdata/isiri-3342.h
new file mode 100644
index 0000000000..33ef1bb0e0
--- /dev/null
+++ b/iconvdata/isiri-3342.h
@@ -0,0 +1,325 @@
+static const uint32_t to_ucs4[256] = {
+  [0x01] = 0x0001,
+  [0x02] = 0x0002,
+  [0x03] = 0x0003,
+  [0x04] = 0x0004,
+  [0x05] = 0x0005,
+  [0x06] = 0x0006,
+  [0x07] = 0x0007,
+  [0x08] = 0x0008,
+  [0x09] = 0x0009,
+  [0x0a] = 0x000A,
+  [0x0b] = 0x000B,
+  [0x0c] = 0x000C,
+  [0x0d] = 0x000D,
+  [0x0e] = 0x000E,
+  [0x0f] = 0x000F,
+  [0x10] = 0x0010,
+  [0x11] = 0x0011,
+  [0x12] = 0x0012,
+  [0x13] = 0x0013,
+  [0x14] = 0x0014,
+  [0x15] = 0x0015,
+  [0x16] = 0x0016,
+  [0x17] = 0x0017,
+  [0x18] = 0x0018,
+  [0x19] = 0x0019,
+  [0x1a] = 0x001A,
+  [0x1b] = 0x001B,
+  [0x1c] = 0x001C,
+  [0x1d] = 0x001D,
+  [0x1e] = 0x001E,
+  [0x1f] = 0x001F,
+  [0x20] = 0x0020,
+  [0x21] = 0x0021,
+  [0x22] = 0x0022,
+  [0x23] = 0x0023,
+  [0x24] = 0x0024,
+  [0x25] = 0x0025,
+  [0x26] = 0x0026,
+  [0x27] = 0x0027,
+  [0x28] = 0x0028,
+  [0x29] = 0x0029,
+  [0x2a] = 0x002A,
+  [0x2b] = 0x002B,
+  [0x2c] = 0x002C,
+  [0x2d] = 0x002D,
+  [0x2e] = 0x002E,
+  [0x2f] = 0x002F,
+  [0x30] = 0x0030,
+  [0x31] = 0x0031,
+  [0x32] = 0x0032,
+  [0x33] = 0x0033,
+  [0x34] = 0x0034,
+  [0x35] = 0x0035,
+  [0x36] = 0x0036,
+  [0x37] = 0x0037,
+  [0x38] = 0x0038,
+  [0x39] = 0x0039,
+  [0x3a] = 0x003A,
+  [0x3b] = 0x003B,
+  [0x3c] = 0x003C,
+  [0x3d] = 0x003D,
+  [0x3e] = 0x003E,
+  [0x3f] = 0x003F,
+  [0x40] = 0x0040,
+  [0x41] = 0x0041,
+  [0x42] = 0x0042,
+  [0x43] = 0x0043,
+  [0x44] = 0x0044,
+  [0x45] = 0x0045,
+  [0x46] = 0x0046,
+  [0x47] = 0x0047,
+  [0x48] = 0x0048,
+  [0x49] = 0x0049,
+  [0x4a] = 0x004A,
+  [0x4b] = 0x004B,
+  [0x4c] = 0x004C,
+  [0x4d] = 0x004D,
+  [0x4e] = 0x004E,
+  [0x4f] = 0x004F,
+  [0x50] = 0x0050,
+  [0x51] = 0x0051,
+  [0x52] = 0x0052,
+  [0x53] = 0x0053,
+  [0x54] = 0x0054,
+  [0x55] = 0x0055,
+  [0x56] = 0x0056,
+  [0x57] = 0x0057,
+  [0x58] = 0x0058,
+  [0x59] = 0x0059,
+  [0x5a] = 0x005A,
+  [0x5b] = 0x005B,
+  [0x5c] = 0x005C,
+  [0x5d] = 0x005D,
+  [0x5e] = 0x005E,
+  [0x5f] = 0x005F,
+  [0x60] = 0x0060,
+  [0x61] = 0x0061,
+  [0x62] = 0x0062,
+  [0x63] = 0x0063,
+  [0x64] = 0x0064,
+  [0x65] = 0x0065,
+  [0x66] = 0x0066,
+  [0x67] = 0x0067,
+  [0x68] = 0x0068,
+  [0x69] = 0x0069,
+  [0x6a] = 0x006A,
+  [0x6b] = 0x006B,
+  [0x6c] = 0x006C,
+  [0x6d] = 0x006D,
+  [0x6e] = 0x006E,
+  [0x6f] = 0x006F,
+  [0x70] = 0x0070,
+  [0x71] = 0x0071,
+  [0x72] = 0x0072,
+  [0x73] = 0x0073,
+  [0x74] = 0x0074,
+  [0x75] = 0x0075,
+  [0x76] = 0x0076,
+  [0x77] = 0x0077,
+  [0x78] = 0x0078,
+  [0x79] = 0x0079,
+  [0x7a] = 0x007A,
+  [0x7b] = 0x007B,
+  [0x7c] = 0x007C,
+  [0x7d] = 0x007D,
+  [0x7e] = 0x007E,
+  [0x7f] = 0x007F,
+  [0x80] = 0x0000,
+  [0x81] = 0x0001,
+  [0x82] = 0x0002,
+  [0x83] = 0x0003,
+  [0x84] = 0x0004,
+  [0x85] = 0x0005,
+  [0x86] = 0x0006,
+  [0x87] = 0x0007,
+  [0x88] = 0x0008,
+  [0x89] = 0x0009,
+  [0x8a] = 0x000A,
+  [0x8b] = 0x000B,
+  [0x8c] = 0x000C,
+  [0x8d] = 0x000D,
+  [0x8e] = 0x000E,
+  [0x8f] = 0x000F,
+  [0x90] = 0x0010,
+  [0x91] = 0x0011,
+  [0x92] = 0x0012,
+  [0x93] = 0x0013,
+  [0x94] = 0x0014,
+  [0x95] = 0x0015,
+  [0x96] = 0x0016,
+  [0x97] = 0x0017,
+  [0x98] = 0x0018,
+  [0x99] = 0x0019,
+  [0x9a] = 0x001A,
+  [0x9b] = 0x001B,
+  [0x9c] = 0x001C,
+  [0x9d] = 0x001D,
+  [0x9e] = 0x001E,
+  [0x9f] = 0x001F,
+  [0xa0] = 0x0020,
+  [0xa1] = 0x200C,
+  [0xa2] = 0x200D,
+  [0xa3] = 0x0021,
+  [0xa4] = 0x00A4,
+  [0xa5] = 0x066A,
+  [0xa6] = 0x002E,
+  [0xa7] = 0x066C,
+  [0xa8] = 0x0029,
+  [0xa9] = 0x0028,
+  [0xaa] = 0x00D7,
+  [0xab] = 0x002B,
+  [0xac] = 0x060C,
+  [0xad] = 0x002D,
+  [0xae] = 0x066B,
+  [0xaf] = 0x002F,
+  [0xb0] = 0x06F0,
+  [0xb1] = 0x06F1,
+  [0xb2] = 0x06F2,
+  [0xb3] = 0x06F3,
+  [0xb4] = 0x06F4,
+  [0xb5] = 0x06F5,
+  [0xb6] = 0x06F6,
+  [0xb7] = 0x06F7,
+  [0xb8] = 0x06F8,
+  [0xb9] = 0x06F9,
+  [0xba] = 0x003A,
+  [0xbb] = 0x061B,
+  [0xbc] = 0x003C,
+  [0xbd] = 0x003D,
+  [0xbe] = 0x003E,
+  [0xbf] = 0x061F,
+  [0xc0] = 0x0622,
+  [0xc1] = 0x0627,
+  [0xc2] = 0x0621,
+  [0xc3] = 0x0628,
+  [0xc4] = 0x067E,
+  [0xc5] = 0x062A,
+  [0xc6] = 0x062B,
+  [0xc7] = 0x062C,
+  [0xc8] = 0x0686,
+  [0xc9] = 0x062D,
+  [0xca] = 0x062E,
+  [0xcb] = 0x062F,
+  [0xcc] = 0x0630,
+  [0xcd] = 0x0631,
+  [0xce] = 0x0632,
+  [0xcf] = 0x0698,
+  [0xd0] = 0x0633,
+  [0xd1] = 0x0634,
+  [0xd2] = 0x0635,
+  [0xd3] = 0x0636,
+  [0xd4] = 0x0637,
+  [0xd5] = 0x0638,
+  [0xd6] = 0x0639,
+  [0xd7] = 0x063A,
+  [0xd8] = 0x0641,
+  [0xd9] = 0x0642,
+  [0xda] = 0x06A9,
+  [0xdb] = 0x06AF,
+  [0xdc] = 0x0644,
+  [0xdd] = 0x0645,
+  [0xde] = 0x0646,
+  [0xdf] = 0x0648,
+  [0xe0] = 0x0647,
+  [0xe1] = 0x06CC,
+  [0xe2] = 0x005D,
+  [0xe3] = 0x005B,
+  [0xe4] = 0x007D,
+  [0xe5] = 0x007B,
+  [0xe6] = 0x00AB,
+  [0xe7] = 0x00BB,
+  [0xe8] = 0x002A,
+  [0xe9] = 0x0640,
+  [0xea] = 0x007C,
+  [0xeb] = 0x005C,
+  [0xf0] = 0x064E,
+  [0xf1] = 0x0650,
+  [0xf2] = 0x064F,
+  [0xf3] = 0x064B,
+  [0xf4] = 0x064D,
+  [0xf5] = 0x064C,
+  [0xf6] = 0x0651,
+  [0xf7] = 0x0652,
+  [0xf8] = 0x0623,
+  [0xf9] = 0x0624,
+  [0xfa] = 0x0625,
+  [0xfb] = 0x0626,
+  [0xfc] = 0x0629,
+  [0xfd] = 0x0643,
+  [0xfe] = 0x064A,
+  [0xff] = 0x007F,
+};
+static const struct gap from_idx[] = {
+  { start: 0x0000, end: 0x007f, idx:     0 },
+  { start: 0x00a4, end: 0x00a4, idx:   -36 },
+  { start: 0x00ab, end: 0x00ab, idx:   -42 },
+  { start: 0x00bb, end: 0x00bb, idx:   -57 },
+  { start: 0x00d7, end: 0x00d7, idx:   -84 },
+  { start: 0x060c, end: 0x060c, idx: -1416 },
+  { start: 0x061b, end: 0x0652, idx: -1430 },
+  { start: 0x066a, end: 0x066c, idx: -1453 },
+  { start: 0x067e, end: 0x067e, idx: -1470 },
+  { start: 0x0686, end: 0x0686, idx: -1477 },
+  { start: 0x0698, end: 0x0698, idx: -1494 },
+  { start: 0x06a9, end: 0x06af, idx: -1510 },
+  { start: 0x06cc, end: 0x06cc, idx: -1538 },
+  { start: 0x06f0, end: 0x06f9, idx: -1573 },
+  { start: 0x200c, end: 0x200d, idx: -7991 },
+  { start: 0xffff, end: 0xffff, idx:     0 }
+};
+static const char from_ucs4[] = {
+  /* 0x0000..0x007f */
+  '\x00', '\x01', '\x02', '\x03', '\x04', '\x05', '\x06', '\x07',
+  '\x08', '\x09', '\x0a', '\x0b', '\x0c', '\x0d', '\x0e', '\x0f',
+  '\x10', '\x11', '\x12', '\x13', '\x14', '\x15', '\x16', '\x17',
+  '\x18', '\x19', '\x1a', '\x1b', '\x1c', '\x1d', '\x1e', '\x1f',
+  '\x20', '\x21', '\x22', '\x23', '\x24', '\x25', '\x26', '\x27',
+  '\x28', '\x29', '\x2a', '\x2b', '\x2c', '\x2d', '\x2e', '\x2f',
+  '\x30', '\x31', '\x32', '\x33', '\x34', '\x35', '\x36', '\x37',
+  '\x38', '\x39', '\x3a', '\x3b', '\x3c', '\x3d', '\x3e', '\x3f',
+  '\x40', '\x41', '\x42', '\x43', '\x44', '\x45', '\x46', '\x47',
+  '\x48', '\x49', '\x4a', '\x4b', '\x4c', '\x4d', '\x4e', '\x4f',
+  '\x50', '\x51', '\x52', '\x53', '\x54', '\x55', '\x56', '\x57',
+  '\x58', '\x59', '\x5a', '\x5b', '\x5c', '\x5d', '\x5e', '\x5f',
+  '\x60', '\x61', '\x62', '\x63', '\x64', '\x65', '\x66', '\x67',
+  '\x68', '\x69', '\x6a', '\x6b', '\x6c', '\x6d', '\x6e', '\x6f',
+  '\x70', '\x71', '\x72', '\x73', '\x74', '\x75', '\x76', '\x77',
+  '\x78', '\x79', '\x7a', '\x7b', '\x7c', '\x7d', '\x7e', '\x7f',
+  /* 0x00a4..0x00a4 */
+  '\xa4',
+  /* 0x00ab..0x00ab */
+  '\xe6',
+  /* 0x00bb..0x00bb */
+  '\xe7',
+  /* 0x00d7..0x00d7 */
+  '\xaa',
+  /* 0x060c..0x060c */
+  '\xac',
+  /* 0x061b..0x0652 */
+  '\xbb', '\x00', '\x00', '\x00', '\xbf', '\x00', '\xc2', '\xc0',
+  '\xf8', '\xf9', '\xfa', '\xfb', '\xc1', '\xc3', '\xfc', '\xc5',
+  '\xc6', '\xc7', '\xc9', '\xca', '\xcb', '\xcc', '\xcd', '\xce',
+  '\xd0', '\xd1', '\xd2', '\xd3', '\xd4', '\xd5', '\xd6', '\xd7',
+  '\x00', '\x00', '\x00', '\x00', '\x00', '\xe9', '\xd8', '\xd9',
+  '\xfd', '\xdc', '\xdd', '\xde', '\xe0', '\xdf', '\x00', '\xfe',
+  '\xf3', '\xf5', '\xf4', '\xf0', '\xf2', '\xf1', '\xf6', '\xf7',
+  /* 0x066a..0x066c */
+  '\xa5', '\xae', '\xa7',
+  /* 0x067e..0x067e */
+  '\xc4',
+  /* 0x0686..0x0686 */
+  '\xc8',
+  /* 0x0698..0x0698 */
+  '\xcf',
+  /* 0x06a9..0x06af */
+  '\xda', '\x00', '\x00', '\x00', '\x00', '\x00', '\xdb',
+  /* 0x06cc..0x06cc */
+  '\xe1',
+  /* 0x06f0..0x06f9 */
+  '\xb0', '\xb1', '\xb2', '\xb3', '\xb4', '\xb5', '\xb6', '\xb7',
+  '\xb8', '\xb9',
+  /* 0x200c..0x200d */
+  '\xa1', '\xa2',
+};
diff --git a/iconvdata/iso_6937.c b/iconvdata/iso_6937.c
index d51f321d33..ccae483c12 100644
--- a/iconvdata/iso_6937.c
+++ b/iconvdata/iso_6937.c
@@ -28,7 +28,7 @@ static const uint32_t to_ucs4[256] =
   /* 0x08 */ 0x0008, 0x0009, 0x000a, 0x000b, 0x000c, 0x000d, 0x000e, 0x000f,
   /* 0x10 */ 0x0010, 0x0011, 0x0012, 0x0013, 0x0014, 0x0015, 0x0016, 0x0017,
   /* 0x18 */ 0x0018, 0x0019, 0x001a, 0x001b, 0x001c, 0x001d, 0x001e, 0x001f,
-  /* 0x20 */ 0x0020, 0x0021, 0x0022, 0x0023, 0x0034, 0x0025, 0x0026, 0x0027,
+  /* 0x20 */ 0x0020, 0x0021, 0x0022, 0x0023, 0x0024, 0x0025, 0x0026, 0x0027,
   /* 0x28 */ 0x0028, 0x0029, 0x002a, 0x002b, 0x002c, 0x002d, 0x002e, 0x002f,
   /* 0x30 */ 0x0030, 0x0031, 0x0032, 0x0033, 0x0034, 0x0035, 0x0036, 0x0037,
   /* 0x38 */ 0x0038, 0x0039, 0x003a, 0x003b, 0x003c, 0x003d, 0x003e, 0x003f,
@@ -46,7 +46,7 @@ static const uint32_t to_ucs4[256] =
   /* 0x98 */ 0x0098, 0x0099, 0x009a, 0x009b, 0x009c, 0x009d, 0x009e, 0x009f,
   /* 0xa0 */ 0x00a0, 0x00a1, 0x00a2, 0x00a3, 0x0000, 0x00a5, 0x0000, 0x00a7,
   /* 0xa8 */ 0x00a4, 0x2018, 0x201c, 0x00ab, 0x2190, 0x2191, 0x2192, 0x2193,
-  /* 0xb0 */ 0x00b0, 0x00b1, 0x00b2, 0x00b3, 0x00b4, 0x00b5, 0x00b6, 0x00b7,
+  /* 0xb0 */ 0x00b0, 0x00b1, 0x00b2, 0x00b3, 0x00d7, 0x00b5, 0x00b6, 0x00b7,
   /* 0xb8 */ 0x00f7, 0x2019, 0x201d, 0x00bb, 0x00bc, 0x00bd, 0x00be, 0x00bf,
   /* 0xc0 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
   /* 0xc8 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
@@ -302,7 +302,7 @@ static const char from_ucs4[][2] =
   /* 0x0091 */ "\x91\x00", "\x92\x00", "\x93\x00", "\x94\x00", "\x95\x00",
   /* 0x0096 */ "\x96\x00", "\x97\x00", "\x98\x00", "\x99\x00", "\x9a\x00",
   /* 0x009b */ "\x9b\x00", "\x9c\x00", "\x9d\x00", "\x9e\x00", "\x9f\x00",
-  /* 0x00a0 */ "\xa0\x00", "\xa1\x00", "\xa2\x00", "\xa3\x00", "\xa4\x00",
+  /* 0x00a0 */ "\xa0\x00", "\xa1\x00", "\xa2\x00", "\xa3\x00", "\xa8\x00",
   /* 0x00a5 */ "\xa5\x00", "\xd7\x00", "\xa7\x00", "\xc8\x20", "\xd3\x00",
   /* 0x00aa */ "\xe3\x00", "\xab\x00", "\xd6\x00", "\xff\x00", "\xd2\x00",
   /* 0x00af */ "\xc5\x20", "\xb0\x00", "\xb1\x00", "\xb2\x00", "\xb3\x00",
@@ -317,7 +317,7 @@ static const char from_ucs4[][2] =
   /* 0x00dc */ "\xc8\x55", "\xc2\x59", "\xec\x00", "\xfb\x00", "\xc1\x61",
   /* 0x00e1 */ "\xc2\x61", "\xc3\x61", "\xc4\x61", "\xc8\x61", "\xca\x61",
   /* 0x00e6 */ "\xf1\x00", "\xcb\x63", "\xc1\x65", "\xc2\x65", "\xc3\x65",
-  /* 0x00eb */ "\xc8\x65", "\xc1\x69", "\xc2\xe9", "\xc3\x69", "\xc8\x69",
+  /* 0x00eb */ "\xc8\x65", "\xc1\x69", "\xc2\x69", "\xc3\x69", "\xc8\x69",
   /* 0x00f0 */ "\xf3\x00", "\xc4\x6e", "\xc1\x6f", "\xc2\x6f", "\xc3\x6f",
   /* 0x00f5 */ "\xc4\x6f", "\xc8\x6f", "\xb8\x00", "\xf9\x00", "\xc1\x75",
   /* 0x00fa */ "\xc2\x75", "\xc3\x75", "\xc8\x75", "\xc2\x79", "\xfc\x00",
@@ -491,7 +491,8 @@ static const char from_ucs4[][2] =
 	  case 0x2c7:							      \
 	    cp = "\xcf\x20";						      \
 	    break;							      \
-	  case 0x2d8 ... 0x2dd:						      \
+	  case 0x2d8 ... 0x2db:						      \
+	  case 0x2dd:							      \
 	    {								      \
 	      static const char map[6] = "\xc6\xc7\xca\xce\x00\xcd";	      \
 									      \
diff --git a/iconvdata/johab.c b/iconvdata/johab.c
index 46649c5923..e4603cb423 100644
--- a/iconvdata/johab.c
+++ b/iconvdata/johab.c
@@ -413,6 +413,7 @@ johab_sym_hanja_to_ucs (uint_fast32_t idx, uint_fast32_t c1, uint_fast32_t c2)
 	else								      \
 	  {								      \
 	    size_t written;						      \
+	    uint32_t temp;						      \
 									      \
 	    written = ucs4_to_ksc5601_sym (ch, outptr, outend - outptr);      \
 	    if (__builtin_expect (written, 1) == 0)			      \
@@ -425,14 +426,10 @@ johab_sym_hanja_to_ucs (uint_fast32_t idx, uint_fast32_t c1, uint_fast32_t c2)
 		STANDARD_ERR_HANDLER (4);				      \
 	      }								      \
 									      \
-	    outptr[0] -= 0x4a;						      \
-	    outptr[1] += 0x80;						      \
-									      \
-	    outptr[1] += (outptr[0] % 2					      \
-			  ? 0 : (outptr[1] > 0xee ? 0x43 : 0x31));	      \
-	    outptr[1] -= 0xa1;						      \
-	    outptr[0] /= 2;						      \
-	    outptr[0] += 0xe0;						      \
+	    temp = (outptr[0] < 0x4a ? outptr[0] + 0x191 : outptr[0] + 0x176);\
+	    outptr[1] += (temp % 2 ? 0x5e : 0);				      \
+	    outptr[1] += (outptr[1] < 0x6f ? 0x10 : 0x22);		      \
+	    outptr[0] = temp / 2;					      \
 									      \
 	    outptr += 2;						      \
 	  }								      \
diff --git a/iconvdata/macintosh.c b/iconvdata/macintosh.c
index fba1cbdc97..4bf75faed6 100644
--- a/iconvdata/macintosh.c
+++ b/iconvdata/macintosh.c
@@ -1,5 +1,5 @@
 /* Conversion from and to MACINTOSH.
-   Copyright (C) 1998 Free Software Foundation, Inc.
+   Copyright (C) 1998, 2000 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
 
@@ -24,6 +24,6 @@
 #define TABLES <macintosh.h>
 
 #define CHARSET_NAME	"MACINTOSH//"
-#define HAS_HOLES	0	/* All 256 character are defined.  */
+#define HAS_HOLES	1	/* Not all 256 characters are defined.  */
 
 #include <8bit-gap.c>
diff --git a/iconvdata/sjis.c b/iconvdata/sjis.c
index 29d558f60c..60d1e28508 100644
--- a/iconvdata/sjis.c
+++ b/iconvdata/sjis.c
@@ -4388,7 +4388,8 @@ static const char from_ucs4_extra[0x100][2] =
 									      \
 	ch2 = inptr[1];							      \
 	idx = ch * 256 + ch2;						      \
-	if (__builtin_expect (idx, 0x8140) < 0x8140			      \
+	if (__builtin_expect (ch < 0x81, 0)				      \
+	    || __builtin_expect (ch2 < 0x40, 0)				      \
 	    || (__builtin_expect (idx, 0x8140) > 0x84be && idx < 0x889f)      \
 	    || (__builtin_expect (idx, 0x8140) > 0x88fc && idx < 0x8940)      \
 	    || (__builtin_expect (idx, 0x8140) > 0x9ffc && idx < 0xe040)      \
diff --git a/iconvdata/t.61.c b/iconvdata/t.61.c
index 611eca8b39..17a22a3cd1 100644
--- a/iconvdata/t.61.c
+++ b/iconvdata/t.61.c
@@ -46,10 +46,10 @@ static const uint32_t to_ucs4[256] =
   /* 0x88 */ 0x0088, 0x0089, 0x008a, 0x008b, 0x008c, 0x008d, 0x008e, 0x008f,
   /* 0x90 */ 0x0090, 0x0091, 0x0092, 0x0093, 0x0094, 0x0095, 0x0096, 0x0097,
   /* 0x98 */ 0x0098, 0x0099, 0x009a, 0x009b, 0x009c, 0x009d, 0x009e, 0x009f,
-  /* 0xa0 */ 0x0000, 0x00a1, 0x00a2, 0x00a3, 0x00a4, 0x00a5, 0x00a6, 0x00a7,
-  /* 0xa8 */ 0x00a8, 0x0000, 0x0000, 0x00ab, 0x0000, 0x0000, 0x0000, 0x0000,
-  /* 0xb0 */ 0x00b0, 0x00b1, 0x00b2, 0x00b3, 0x00b4, 0x00b5, 0x00b6, 0x00b7,
-  /* 0xb8 */ 0x00b8, 0x0000, 0x0000, 0x00bb, 0x00bc, 0x00bd, 0x00be, 0x00bf,
+  /* 0xa0 */ 0x0000, 0x00a1, 0x00a2, 0x00a3, 0x0024, 0x00a5, 0x0023, 0x00a7,
+  /* 0xa8 */ 0x00a4, 0x0000, 0x0000, 0x00ab, 0x0000, 0x0000, 0x0000, 0x0000,
+  /* 0xb0 */ 0x00b0, 0x00b1, 0x00b2, 0x00b3, 0x00d7, 0x00b5, 0x00b6, 0x00b7,
+  /* 0xb8 */ 0x00f7, 0x0000, 0x0000, 0x00bb, 0x00bc, 0x00bd, 0x00be, 0x00bf,
   /* 0xc0 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
   /* 0xc8 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
   /* 0xd0 */ 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
@@ -304,12 +304,12 @@ static const char from_ucs4[][2] =
   /* 0x0091 */ "\x91\x00", "\x92\x00", "\x93\x00", "\x94\x00", "\x95\x00",
   /* 0x0096 */ "\x96\x00", "\x97\x00", "\x98\x00", "\x99\x00", "\x9a\x00",
   /* 0x009b */ "\x9b\x00", "\x9c\x00", "\x9d\x00", "\x9e\x00", "\x9f\x00",
-  /* 0x00a0 */ "\x00\x00", "\xa1\x00", "\xa2\x00", "\xa3\x00", "\xa4\x00",
+  /* 0x00a0 */ "\x00\x00", "\xa1\x00", "\xa2\x00", "\xa3\x00", "\xa8\x00",
   /* 0x00a5 */ "\xa5\x00", "\x00\x00", "\xa7\x00", "\xc8\x20", "\x00\x00",
   /* 0x00aa */ "\xe3\x00", "\xab\x00", "\x00\x00", "\x00\x00", "\x00\x00",
   /* 0x00af */ "\xc5\x20", "\xb0\x00", "\xb1\x00", "\xb2\x00", "\xb3\x00",
   /* 0x00b4 */ "\xc2\x20", "\xb5\x00", "\xb6\x00", "\xb7\x00", "\xcb\x20",
-  /* 0x00b9 */ "\x00\x00", "\xeb\x00", "\x00\x00", "\xbc\x00", "\xbd\x00",
+  /* 0x00b9 */ "\x00\x00", "\xeb\x00", "\xbb\x00", "\xbc\x00", "\xbd\x00",
   /* 0x00be */ "\xbe\x00", "\xbf\x00", "\xc1\x41", "\xc2\x41", "\xc3\x41",
   /* 0x00c3 */ "\xc4\x41", "\xc8\x41", "\xca\x41", "\xe1\x00", "\xcb\x43",
   /* 0x00c8 */ "\xc1\x45", "\xc2\x45", "\xc3\x45", "\xc8\x45", "\xc1\x49",
@@ -319,7 +319,7 @@ static const char from_ucs4[][2] =
   /* 0x00dc */ "\xc8\x55", "\xc2\x59", "\xec\x00", "\xfb\x00", "\xc1\x61",
   /* 0x00e1 */ "\xc2\x61", "\xc3\x61", "\xc4\x61", "\xc8\x61", "\xca\x61",
   /* 0x00e6 */ "\xf1\x00", "\xcb\x63", "\xc1\x65", "\xc2\x65", "\xc3\x65",
-  /* 0x00eb */ "\xc8\x65", "\xc1\x69", "\xc2\xe9", "\xc3\x69", "\xc8\x69",
+  /* 0x00eb */ "\xc8\x65", "\xc1\x69", "\xc2\x69", "\xc3\x69", "\xc8\x69",
   /* 0x00f0 */ "\xf3\x00", "\xc4\x6e", "\xc1\x6f", "\xc2\x6f", "\xc3\x6f",
   /* 0x00f5 */ "\xc4\x6f", "\xc8\x6f", "\xb8\x00", "\xf9\x00", "\xc1\x75",
   /* 0x00fa */ "\xc2\x75", "\xc3\x75", "\xc8\x75", "\xc2\x79", "\xfc\x00",
diff --git a/iconvdata/uhc.c b/iconvdata/uhc.c
index 38ae65ba2e..c191b1127e 100644
--- a/iconvdata/uhc.c
+++ b/iconvdata/uhc.c
@@ -3118,6 +3118,7 @@ static const char uhc_hangul_from_ucs[11172][2] =
 	  {								      \
 	    if (__builtin_expect (ch, 0xc5) > 0xc6			      \
 		|| __builtin_expect (ch2, 0x41) < 0x41			      \
+		|| __builtin_expect (ch2, 0x41) > 0xfe			      \
 		|| (__builtin_expect (ch2, 0x41) > 0x5a && ch2 < 0x61)	      \
 		|| (__builtin_expect (ch2, 0x41) > 0x7a && ch2 < 0x81)	      \
 		|| (__builtin_expect (ch, 0xc5) == 0xc6 && ch2 > 0x52))	      \
@@ -3194,9 +3195,9 @@ static const char uhc_hangul_from_ucs[11172][2] =
   {									      \
     uint32_t ch = get32 (inptr);					      \
 									      \
-    if (ch < 0x7f)							      \
+    if (ch <= 0x7f)							      \
       /* XXX Think about 0x5c ; '\'.  */				      \
-      *outptr = ch;							      \
+      *outptr++ = ch;							      \
     else if (ch >= 0xac00 && ch <= 0xd7a3)				      \
       {									      \
 	const char *s = uhc_hangul_from_ucs[ch - 0xac00];		      \
diff --git a/string/strxfrm.c b/string/strxfrm.c
index 7ddc5f3f81..dd0ad67835 100644
--- a/string/strxfrm.c
+++ b/string/strxfrm.c
@@ -46,24 +46,11 @@
 
 
 #ifndef WIDE_CHAR_VERSION
-/* These are definitions used by some of the functions for handling
-   UTF-8 encoding below.  */
-static const uint32_t encoding_mask[] =
-{
-  ~0x7ff, ~0xffff, ~0x1fffff, ~0x3ffffff
-};
-
-static const unsigned char encoding_byte[] =
-{
-  0xc0, 0xe0, 0xf0, 0xf8, 0xfc
-};
-
 
 /* We need UTF-8 encoding of numbers.  */
 static inline int
 utf8_encode (char *buf, int val)
 {
-  char *startp = buf;
   int retval;
 
   if (val < 0x80)
@@ -76,11 +63,11 @@ utf8_encode (char *buf, int val)
       int step;
 
       for (step = 2; step < 6; ++step)
-	if ((val & encoding_mask[step - 2]) == 0)
+	if ((val & (~(uint32_t)0 << (5 * step + 1))) == 0)
 	  break;
       retval = step;
 
-      *buf = encoding_byte[step - 2];
+      *buf = (unsigned char) (~0xff >> step);
       --step;
       do
 	{
@@ -91,7 +78,7 @@ utf8_encode (char *buf, int val)
       *buf |= val;
     }
 
-  return buf - startp;
+  return retval;
 }
 #endif