2000-10-31  Ulrich Drepper  <drepper@redhat.com>

	* iconvdata/Makefile (modules): Add IBM856, IBM930, IBM933, IBM935,
	IBM937, IBM939, and IBM1046.
	(distribute): Add ibm856.c, ibm930.c, ibm933.c, ibm935.c, ibm937.c,
	ibm939.c, ibm1046.c, ibm856.h, ibm930.h, ibm933.h, ibm935.h, ibm937.h,
	ibm939.h, and ibm1046.h.
	* iconvdata/gconv-modules: Add entries for IBM856, IBM930, IBM933,
	IBM935, IBM937, IBM939, and IBM1046.
	Patches by Masahide Washizawa <washi@yamato.ibm.co.jp>.
This commit is contained in:
Ulrich Drepper 2000-10-31 08:24:06 +00:00
parent beaaf574bf
commit dbd10df75f
17 changed files with 46214 additions and 0 deletions

View file

@ -1,3 +1,14 @@
2000-10-31 Ulrich Drepper <drepper@redhat.com>
* iconvdata/Makefile (modules): Add IBM856, IBM930, IBM933, IBM935,
IBM937, IBM939, and IBM1046.
(distribute): Add ibm856.c, ibm930.c, ibm933.c, ibm935.c, ibm937.c,
ibm939.c, ibm1046.c, ibm856.h, ibm930.h, ibm933.h, ibm935.h, ibm937.h,
ibm939.h, and ibm1046.h.
* iconvdata/gconv-modules: Add entries for IBM856, IBM930, IBM933,
IBM935, IBM937, IBM939, and IBM1046.
Patches by Masahide Washizawa <washi@yamato.ibm.co.jp>.
2000-10-30 Ulrich Drepper <drepper@redhat.com>
* locale/localeinfo.h (enum value_type): Add wstring, wstringarray,

View file

@ -38,6 +38,7 @@ modules := ISO8859-1 ISO8859-2 ISO8859-3 ISO8859-4 ISO8859-5 \
IBM437 IBM850 IBM851 IBM852 IBM855 IBM857 IBM860 IBM861 \
IBM862 IBM863 IBM864 IBM865 IBM868 IBM869 IBM875 IBM880 \
IBM866 CP1258 \
IBM856 IBM930 IBM933 IBM935 IBM937 IBM939 IBM1046 \
IBM918 IBM1004 IBM1026 CP1250 CP1251 CP1252 CP1253 CP1254 \
CP1255 CP1256 CP1257 ISO-2022-JP MACINTOSH IEC_P27-1 \
ASMO_449 ANSI_X3.110 CSN_369103 CWI DEC-MCS ECMA-CYRILLIC \
@ -118,6 +119,8 @@ distribute := gconv-modules extra-module.mk gap.awk gaptab.awk \
ibm861.c ibm862.c ibm863.c ibm864.c ibm865.c ibm866.c \
ibm868.c ibm869.c ibm870.c ibm871.c ibm875.c ibm880.c \
ibm891.c ibm903.c ibm904.c ibm905.c ibm918.c ibm1004.c \
ibm856.c ibm930.c ibm933.c ibm935.c ibm937.c ibm939.c ibm1046.c \
ibm856.h ibm930.h ibm933.h ibm935.h ibm937.h ibm939.h ibm1046.h \
ibm1026.c ibm1047.c iec_p27-1.c inis.c inis-8.c \
inis-cyrillic.c iso-2022-jp.c iso-2022-kr.c iso646.c \
iso8859-1.c iso8859-2.c iso8859-3.c iso8859-4.c iso8859-5.c \

View file

@ -686,6 +686,14 @@ alias OSF10020357// IBM855//
module IBM855// INTERNAL IBM855 1
module INTERNAL IBM855// IBM855 1
# from to module cost
alias IBM-856// IBM856//
alias CP856// IBM856//
alias 856// IBM856//
alias CSIBM856// IBM856//
module IBM856// INTERNAL IBM856 1
module INTERNAL IBM856// IBM856 1
# from to module cost
alias CP857// IBM857//
alias 857// IBM857//
@ -833,6 +841,46 @@ alias OSF10020396// IBM918//
module IBM918// INTERNAL IBM918 1
module INTERNAL IBM918// IBM918 1
# from to module cost
alias IBM-930// IBM930//
alias CP930// IBM930//
alias EBCDIC-CP-AR2// IBM930//
alias CSIBM930// IBM930//
module IBM930// INTERNAL IBM930 1
module INTERNAL IBM930// IBM930 1
# from to module cost
alias IBM-933// IBM933//
alias CP933// IBM933//
alias EBCDIC-CP-AR2// IBM933//
alias CSIBM933// IBM933//
module IBM933// INTERNAL IBM933 1
module INTERNAL IBM933// IBM933 1
# from to module cost
alias IBM-935// IBM935//
alias CP935// IBM935//
alias EBCDIC-CP-AR2// IBM935//
alias CSIBM935// IBM935//
module IBM935// INTERNAL IBM935 1
module INTERNAL IBM935// IBM935 1
# from to module cost
alias IBM-937// IBM937//
alias CP937// IBM937//
alias EBCDIC-CP-AR2// IBM937//
alias CSIBM937// IBM937//
module IBM937// INTERNAL IBM937 1
module INTERNAL IBM937// IBM937 1
# from to module cost
alias IBM-939// IBM939//
alias CP939// IBM939//
alias EBCDIC-CP-AR2// IBM939//
alias CSIBM939// IBM939//
module IBM939// INTERNAL IBM939 1
module INTERNAL IBM939// IBM939 1
# from to module cost
alias CP1004// IBM1004//
alias OS2LATIN1// IBM1004//
@ -847,6 +895,13 @@ alias OSF10020402// IBM1026//
module IBM1026// INTERNAL IBM1026 1
module INTERNAL IBM1026// IBM1026 1
# from to module cost
alias IBM-1046// IBM1046//
alias CP1046// IBM1046//
alias 1046// IBM1046//
module IBM1046// INTERNAL IBM1046 1
module INTERNAL IBM1046// IBM1046 1
# from to module cost
alias CP1047// IBM1047//
alias 1047// IBM1047//

29
iconvdata/ibm1046.c Normal file
View file

@ -0,0 +1,29 @@
/* Conversion from and to IBM1046.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <stdint.h>
/* Get the conversion table. */
#define TABLES <ibm1046.h>
#define CHARSET_NAME "IBM1046//"
#define HAS_HOLES 1 /* Not all 256 character are defined. */
#include <8bit-gap.c>

172
iconvdata/ibm1046.h Normal file
View file

@ -0,0 +1,172 @@
/* Tables for conversion from and to IBM1046.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
static const uint32_t to_ucs4[256] =
{
[0x00] = 0x0000, [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] = 0xfe88, [0x81] = 0x00d7, [0x82] = 0x00f7, [0x83] = 0xfeb1,
[0x84] = 0xfeb5, [0x85] = 0xfeb9, [0x86] = 0xfebd, [0x87] = 0xfe71,
[0x88] = 0x0088, [0x89] = 0x25a0, [0x8a] = 0x2502, [0x8b] = 0x2500,
[0x8c] = 0x2510, [0x8d] = 0x250c, [0x8e] = 0x2514, [0x8f] = 0x2518,
[0x90] = 0xfe79, [0x91] = 0xfe7b, [0x92] = 0xfe7d, [0x93] = 0xfe7f,
[0x94] = 0xfe77, [0x95] = 0xfe8a, [0x96] = 0xfef0, [0x97] = 0xfef3,
[0x98] = 0xfef2, [0x99] = 0xfece, [0x9a] = 0xfecf, [0x9b] = 0xfed0,
[0x9c] = 0xfef6, [0x9d] = 0xfef8, [0x9e] = 0xfefa, [0x9f] = 0xfefc,
[0xa0] = 0x00a0, [0xa1] = 0xfe82, [0xa2] = 0xfe84, [0xa3] = 0xfe88,
[0xa4] = 0x00a4, [0xa5] = 0xfe8e, [0xa6] = 0xfe8b, [0xa7] = 0xfe91,
[0xa8] = 0xfe97, [0xa9] = 0xfe9b, [0xaa] = 0xfe9f, [0xab] = 0xfea3,
[0xac] = 0x060c, [0xad] = 0x00ad, [0xae] = 0xfea7, [0xaf] = 0xfeb3,
[0xb0] = 0x0660, [0xb1] = 0x0661, [0xb2] = 0x0662, [0xb3] = 0x0663,
[0xb4] = 0x0664, [0xb5] = 0x0665, [0xb6] = 0x0666, [0xb7] = 0x0667,
[0xb8] = 0x0668, [0xb9] = 0x0669, [0xba] = 0xfeb7, [0xbb] = 0x061b,
[0xbc] = 0xfebb, [0xbd] = 0xfebf, [0xbe] = 0xfeca, [0xbf] = 0x061f,
[0xc0] = 0xfecb, [0xc1] = 0x0621, [0xc2] = 0x0622, [0xc3] = 0x0623,
[0xc4] = 0x0624, [0xc5] = 0x0625, [0xc6] = 0x0626, [0xc7] = 0x0627,
[0xc8] = 0x0628, [0xc9] = 0x0629, [0xca] = 0x062a, [0xcb] = 0x062b,
[0xcc] = 0x062c, [0xcd] = 0x062d, [0xce] = 0x062e, [0xcf] = 0x062f,
[0xd0] = 0x0630, [0xd1] = 0x0631, [0xd2] = 0x0632, [0xd3] = 0x0633,
[0xd4] = 0x0634, [0xd5] = 0x0635, [0xd6] = 0x0636, [0xd7] = 0x0637,
[0xd8] = 0x0638, [0xd9] = 0x0639, [0xda] = 0x063a, [0xdb] = 0xfecc,
[0xdc] = 0xfe82, [0xdd] = 0xfe84, [0xde] = 0xfe8e, [0xdf] = 0xfed3,
[0xe0] = 0x0640, [0xe1] = 0x0641, [0xe2] = 0x0642, [0xe3] = 0x0643,
[0xe4] = 0x0644, [0xe5] = 0x0645, [0xe6] = 0x0646, [0xe7] = 0x0647,
[0xe8] = 0x0648, [0xe9] = 0x0649, [0xea] = 0x064a, [0xeb] = 0x064b,
[0xec] = 0x064c, [0xed] = 0x064d, [0xee] = 0x064e, [0xef] = 0x064f,
[0xf0] = 0x0650, [0xf1] = 0x0651, [0xf2] = 0x0652, [0xf3] = 0xfed7,
[0xf4] = 0xfedb, [0xf5] = 0xfedf, [0xf6] = 0x200b, [0xf7] = 0xfef5,
[0xf8] = 0xfef7, [0xf9] = 0xfef9, [0xfa] = 0xfefb, [0xfb] = 0xfee3,
[0xfc] = 0xfee7, [0xfd] = 0xfeec, [0xfe] = 0xfee9
};
static const struct gap from_idx[] =
{
{ start: 0x0000, end: 0x007f, idx: 0 },
{ start: 0x0088, end: 0x0088, idx: -8 },
{ start: 0x00a0, end: 0x00a0, idx: -31 },
{ start: 0x00a4, end: 0x00a4, idx: -34 },
{ start: 0x00ad, end: 0x00ad, idx: -42 },
{ start: 0x00d7, end: 0x00d7, idx: -83 },
{ start: 0x00f7, end: 0x00f7, idx: -114 },
{ start: 0x060c, end: 0x060c, idx: -1414 },
{ start: 0x061b, end: 0x061b, idx: -1428 },
{ start: 0x061f, end: 0x061f, idx: -1431 },
{ start: 0x0621, end: 0x063a, idx: -1432 },
{ start: 0x0640, end: 0x0652, idx: -1437 },
{ start: 0x0660, end: 0x066d, idx: -1450 },
{ start: 0x200b, end: 0x200b, idx: -8007 },
{ start: 0x2500, end: 0x2500, idx: -9275 },
{ start: 0x2502, end: 0x2502, idx: -9276 },
{ start: 0x250c, end: 0x250c, idx: -9285 },
{ start: 0x2510, end: 0x2510, idx: -9288 },
{ start: 0x2514, end: 0x2514, idx: -9291 },
{ start: 0x2518, end: 0x2518, idx: -9294 },
{ start: 0x25a0, end: 0x25a0, idx: -9429 },
{ start: 0xfe70, end: 0xfe72, idx: -64932 },
{ start: 0xfe74, end: 0xfe74, idx: -64933 },
{ start: 0xfe76, end: 0xfefc, idx: -64934 },
{ start: 0xff01, end: 0xff5e, idx: -64938 },
{ start: 0xffe8, end: 0xffe8, idx: -65075 },
{ start: 0xffed, end: 0xffed, idx: -65079 },
{ start: 0xffff, end: 0xffff, idx: 0 }
};
static const char from_ucs4[] =
{
'\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', '\x88', '\xa0', '\xa4', '\xad', '\x81', '\x82', '\xac',
'\xbb', '\xbf', '\xc1', '\xc2', '\xc3', '\xc4', '\xc5', '\xc6', '\xc7',
'\xc8', '\xc9', '\xca', '\xcb', '\xcc', '\xcd', '\xce', '\xcf', '\xd0',
'\xd1', '\xd2', '\xd3', '\xd4', '\xd5', '\xd6', '\xd7', '\xd8', '\xd9',
'\xda', '\xe0', '\xe1', '\xe2', '\xe3', '\xe4', '\xe5', '\xe6', '\xe7',
'\xe8', '\xe9', '\xea', '\xeb', '\xec', '\xed', '\xee', '\xef', '\xf0',
'\xf1', '\xf2', '\xb0', '\xb1', '\xb2', '\xb3', '\xb4', '\xb5', '\xb6',
'\xb7', '\xb8', '\xb9', '\x25', '\x2c', '\x2e', '\x2a', '\xf6', '\x8b',
'\x8a', '\x8d', '\x8c', '\x8e', '\x8f', '\x89', '\xeb', '\x87', '\xec',
'\xed', '\xee', '\x94', '\xef', '\x90', '\xf0', '\x91', '\xf1', '\x92',
'\xf2', '\x93', '\xc1', '\xc2', '\xdc', '\xc3', '\xdd', '\xc4', '\xc4',
'\xc5', '\x80', '\xc6', '\x95', '\xa6', '\xa6', '\xc7', '\xde', '\xc8',
'\xc8', '\xa7', '\xa7', '\xc9', '\xc9', '\xca', '\xca', '\xa8', '\xa8',
'\xcb', '\xcb', '\xa9', '\xa9', '\xcc', '\xcc', '\xaa', '\xaa', '\xcd',
'\xcd', '\xab', '\xab', '\xce', '\xce', '\xae', '\xae', '\xcf', '\xcf',
'\xd0', '\xd0', '\xd1', '\xd1', '\xd2', '\xd2', '\xd3', '\xd3', '\xaf',
'\xaf', '\xd4', '\xd4', '\xba', '\xba', '\xd5', '\xd5', '\xbc', '\xbc',
'\xd6', '\xd6', '\xbd', '\xbd', '\xd7', '\xd7', '\xd7', '\xd7', '\xd8',
'\xd8', '\xd8', '\xd8', '\xd9', '\xbe', '\xc0', '\xdb', '\xda', '\x99',
'\x9a', '\x9b', '\xe1', '\xe1', '\xdf', '\xdf', '\xe2', '\xe2', '\xf3',
'\xf3', '\xe3', '\xe3', '\xf4', '\xf4', '\xe4', '\xe4', '\xf5', '\xf5',
'\xe5', '\xe5', '\xfb', '\xfb', '\xe6', '\xe6', '\xfc', '\xfc', '\xfe',
'\xfe', '\xe7', '\xfd', '\xe8', '\xe8', '\xe9', '\x96', '\xea', '\x98',
'\x97', '\x97', '\xf7', '\x9c', '\xf8', '\x9d', '\xf9', '\x9e', '\xfa',
'\x9f', '\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', '\x8a', '\x89'
};

29
iconvdata/ibm856.c Normal file
View file

@ -0,0 +1,29 @@
/* Conversion from and to IBM856.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <stdint.h>
/* Get the conversion table. */
#define TABLES <ibm856.h>
#define CHARSET_NAME "IBM856//"
#define HAS_HOLES 1 /* Not all 256 character are defined. */
#include <8bit-gap.c>

185
iconvdata/ibm856.h Normal file
View file

@ -0,0 +1,185 @@
/* Tables for conversion from and to IBM856.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
static const uint32_t to_ucs4[256] =
{
[0x00] = 0x0000, [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] = 0x001c, [0x1b] = 0x001b,
[0x1c] = 0x007f, [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] = 0x001a,
[0x80] = 0x05d0, [0x81] = 0x05d1, [0x82] = 0x05d2, [0x83] = 0x05d3,
[0x84] = 0x05d4, [0x85] = 0x05d5, [0x86] = 0x05d6, [0x87] = 0x05d7,
[0x88] = 0x05d8, [0x89] = 0x05d9, [0x8a] = 0x05da, [0x8b] = 0x05db,
[0x8c] = 0x05dc, [0x8d] = 0x05dd, [0x8e] = 0x05de, [0x8f] = 0x05df,
[0x90] = 0x05e0, [0x91] = 0x05e1, [0x92] = 0x05e2, [0x93] = 0x05e3,
[0x94] = 0x05e4, [0x95] = 0x05e5, [0x96] = 0x05e6, [0x97] = 0x05e7,
[0x98] = 0x05e8, [0x99] = 0x05e9, [0x9a] = 0x05ea, [0x9c] = 0x00a3,
[0x9e] = 0x00d7, [0xa9] = 0x00ae, [0xaa] = 0x00ac, [0xab] = 0x00bd,
[0xac] = 0x00bc, [0xae] = 0x00ab, [0xaf] = 0x00bb, [0xb0] = 0x2591,
[0xb1] = 0x2592, [0xb2] = 0x2593, [0xb3] = 0x2502, [0xb4] = 0x2524,
[0xb8] = 0x00a9, [0xb9] = 0x2563, [0xba] = 0x2551, [0xbb] = 0x2557,
[0xbc] = 0x255d, [0xbd] = 0x00a2, [0xbe] = 0x00a5, [0xbf] = 0x2510,
[0xc0] = 0x2514, [0xc1] = 0x2534, [0xc2] = 0x252c, [0xc3] = 0x251c,
[0xc4] = 0x2500, [0xc5] = 0x253c, [0xc8] = 0x255a, [0xc9] = 0x2554,
[0xca] = 0x2569, [0xcb] = 0x2566, [0xcc] = 0x2560, [0xcd] = 0x2550,
[0xce] = 0x256c, [0xcf] = 0x00a4, [0xd9] = 0x2518, [0xda] = 0x250c,
[0xdb] = 0x2588, [0xdc] = 0x2584, [0xdd] = 0x00a6, [0xdf] = 0x2580,
[0xe6] = 0x00b5, [0xee] = 0x203e, [0xef] = 0x00b4, [0xf0] = 0x00ad,
[0xf1] = 0x00b1, [0xf2] = 0x2017, [0xf3] = 0x00be, [0xf4] = 0x00b6,
[0xf5] = 0x00a7, [0xf6] = 0x00f7, [0xf7] = 0x00b8, [0xf8] = 0x00b0,
[0xf9] = 0x00a8, [0xfa] = 0x2022, [0xfb] = 0x00b9, [0xfc] = 0x00b3,
[0xfd] = 0x00b2, [0xfe] = 0x25a0, [0xff] = 0x00a0
};
static const struct gap from_idx[] =
{
{ start: 0x0000, end: 0x007f, idx: 0 },
{ start: 0x00a0, end: 0x00a0, idx: -32 },
{ start: 0x00a2, end: 0x00a9, idx: -33 },
{ start: 0x00ab, end: 0x00ae, idx: -34 },
{ start: 0x00b0, end: 0x00b6, idx: -35 },
{ start: 0x00b8, end: 0x00b9, idx: -36 },
{ start: 0x00bb, end: 0x00be, idx: -37 },
{ start: 0x00d7, end: 0x00d7, idx: -61 },
{ start: 0x00f7, end: 0x00f7, idx: -92 },
{ start: 0x05d0, end: 0x05ea, idx: -1332 },
{ start: 0x2017, end: 0x2017, idx: -8032 },
{ start: 0x2022, end: 0x2022, idx: -8042 },
{ start: 0x203c, end: 0x203c, idx: -8067 },
{ start: 0x203e, end: 0x203e, idx: -8068 },
{ start: 0x2190, end: 0x2195, idx: -8405 },
{ start: 0x21a8, end: 0x21a8, idx: -8423 },
{ start: 0x221f, end: 0x221f, idx: -8541 },
{ start: 0x2302, end: 0x2302, idx: -8767 },
{ start: 0x2500, end: 0x2500, idx: -9276 },
{ start: 0x2502, end: 0x2502, idx: -9277 },
{ start: 0x250c, end: 0x250c, idx: -9286 },
{ start: 0x2510, end: 0x2510, idx: -9289 },
{ start: 0x2514, end: 0x2514, idx: -9292 },
{ start: 0x2518, end: 0x2518, idx: -9295 },
{ start: 0x251c, end: 0x251c, idx: -9298 },
{ start: 0x2524, end: 0x2524, idx: -9305 },
{ start: 0x252c, end: 0x252c, idx: -9312 },
{ start: 0x2534, end: 0x2534, idx: -9319 },
{ start: 0x253c, end: 0x253c, idx: -9326 },
{ start: 0x2550, end: 0x2551, idx: -9345 },
{ start: 0x2554, end: 0x2554, idx: -9347 },
{ start: 0x2557, end: 0x2557, idx: -9349 },
{ start: 0x255a, end: 0x255a, idx: -9351 },
{ start: 0x255d, end: 0x255d, idx: -9353 },
{ start: 0x2560, end: 0x2560, idx: -9355 },
{ start: 0x2563, end: 0x2563, idx: -9357 },
{ start: 0x2566, end: 0x2566, idx: -9359 },
{ start: 0x2569, end: 0x2569, idx: -9361 },
{ start: 0x256c, end: 0x256c, idx: -9363 },
{ start: 0x2580, end: 0x2580, idx: -9382 },
{ start: 0x2584, end: 0x2584, idx: -9385 },
{ start: 0x2588, end: 0x2588, idx: -9388 },
{ start: 0x2591, end: 0x2593, idx: -9396 },
{ start: 0x25a0, end: 0x25a0, idx: -9408 },
{ start: 0x25ac, end: 0x25ac, idx: -9419 },
{ start: 0x25b2, end: 0x25b2, idx: -9424 },
{ start: 0x25ba, end: 0x25ba, idx: -9431 },
{ start: 0x25bc, end: 0x25bc, idx: -9432 },
{ start: 0x25c4, end: 0x25c4, idx: -9439 },
{ start: 0x25cb, end: 0x25cb, idx: -9445 },
{ start: 0x25d8, end: 0x25d9, idx: -9457 },
{ start: 0x263a, end: 0x263c, idx: -9553 },
{ start: 0x2640, end: 0x2640, idx: -9556 },
{ start: 0x2642, end: 0x2642, idx: -9557 },
{ start: 0x2660, end: 0x2660, idx: -9586 },
{ start: 0x2663, end: 0x2663, idx: -9588 },
{ start: 0x2665, end: 0x2666, idx: -9589 },
{ start: 0x266a, end: 0x266b, idx: -9592 },
{ start: 0xff01, end: 0xff5e, idx: -65037 },
{ start: 0xffe8, end: 0xffee, idx: -65174 },
{ start: 0xffff, end: 0xffff, idx: 0 }
};
static const char from_ucs4[] =
{
'\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', '\x7f',
'\x1b', '\x1a', '\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', '\x1c', '\xff', '\xbd', '\x9c', '\xcf', '\xbe', '\xdd', '\xf5',
'\xf9', '\xb8', '\xae', '\xaa', '\xf0', '\xa9', '\xf8', '\xf1', '\xfd',
'\xfc', '\xef', '\xe6', '\xf4', '\xf7', '\xfb', '\xaf', '\xac', '\xab',
'\xf3', '\x9e', '\xf6', '\x80', '\x81', '\x82', '\x83', '\x84', '\x85',
'\x86', '\x87', '\x88', '\x89', '\x8a', '\x8b', '\x8c', '\x8d', '\x8e',
'\x8f', '\x90', '\x91', '\x92', '\x93', '\x94', '\x95', '\x96', '\x97',
'\x98', '\x99', '\x9a', '\xf2', '\xfa', '\x13', '\xee', '\x1b', '\x18',
'\x1a', '\x19', '\x1d', '\x12', '\x17', '\x1c', '\x7f', '\xc4', '\xb3',
'\xda', '\xbf', '\xc0', '\xd9', '\xc3', '\xb4', '\xc2', '\xc1', '\xc5',
'\xcd', '\xba', '\xc9', '\xbb', '\xc8', '\xbc', '\xcc', '\xb9', '\xcb',
'\xca', '\xce', '\xdf', '\xdc', '\xdb', '\xb0', '\xb1', '\xb2', '\xfe',
'\x16', '\x1e', '\x10', '\x1f', '\x11', '\x09', '\x08', '\x0a', '\x01',
'\x02', '\x0f', '\x0c', '\x0b', '\x06', '\x05', '\x03', '\x04', '\x0d',
'\x0e', '\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', '\xb3', '\x1b', '\x18', '\x1a',
'\x19', '\xfe', '\x09'
};

270
iconvdata/ibm930.c Normal file
View file

@ -0,0 +1,270 @@
/* Conversion from and to IBM930.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
#include <stdint.h>
#include <wchar.h>
#include <byteswap.h>
#include "ibm930.h"
/* The shift sequences for this charset (it does not use ESC). */
#define SI 0x0F /* Shift In, host code to turn DBCS off. */
#define SO 0x0E /* Shift Out, host code to turn DBCS on. */
/* Definitions used in the body of the `gconv' function. */
#define CHARSET_NAME "IBM930//"
#define FROM_LOOP from_ibm930
#define TO_LOOP to_ibm930
/* Definitions of initialization and destructor function. */
#define DEFINE_INIT 1
#define DEFINE_FINI 1
#define MIN_NEEDED_FROM 1
#define MIN_NEEDED_TO 4
/* Current codeset type. */
enum
{
init = 0,
sb,
db
};
/* First, define the conversion function from IBM-930 to UCS4. */
#define MIN_NEEDED_INPUT MIN_NEEDED_FROM
#define MIN_NEEDED_OUTPUT MIN_NEEDED_TO
#define INIT_PARAMS int curcs = init;
#define LOOPFCT FROM_LOOP
#define BODY \
{ \
uint32_t ch = *inptr; \
uint32_t res; \
const struct gap *rp1 = __ibm930sb_to_ucs4_idx; \
const struct gap *rp2 = __ibm930db_to_ucs4_idx; \
\
if (__builtin_expect (ch, 0) == SO) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift OUT, change to DBCS converter. */ \
if (curcs == db) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = db; \
++inptr; \
ch = *inptr; \
} \
else if (__builtin_expect (ch, 0) == SI) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift IN, change to SBCS converter */ \
if (curcs == sb) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = sb; \
++inptr; \
ch = *inptr; \
} \
\
if (curcs == sb || curcs == init) \
{ \
/* Use the IBM930 table for single byte. */ \
while (ch > rp1->end) \
++rp1; \
\
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (res = __ibm930sb_to_ucs4[ch + rp1->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
++inptr; \
continue; \
} \
else \
{ \
if (res == 0xa5) \
res = 0x5c; \
put32 (outptr, res); \
outptr += 4; \
++inptr; \
} \
} \
else if (curcs == db) \
{ \
/* Use the IBM930 table for double byte. */ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
/* The second character is not available. Store the \
intermediate result. */ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
ch = (ch * 0x100) + inptr[1]; \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (res = __ibm930db_to_ucs4[ch + rp2->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
inptr += 2; \
continue; \
} \
else \
{ \
put32 (outptr, res); \
outptr += 4; \
inptr += 2; \
} \
} \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Next, define the other direction. */
#define MIN_NEEDED_INPUT MIN_NEEDED_TO
#define MIN_NEEDED_OUTPUT MIN_NEEDED_FROM
#define INIT_PARAMS int curcs = init;
#define LOOPFCT TO_LOOP
#define BODY \
{ \
uint32_t ch = get32 (inptr); \
const struct gap *rp1 = __ucs4_to_ibm930sb_idx; \
const struct gap *rp2 = __ucs4_to_ibm930db_idx; \
const char *cp; \
\
if (__builtin_expect (ch, 0) >= 0xffff) \
{ \
rp1 = NULL; \
rp2 = NULL; \
} \
else \
while (ch > rp1->end) \
++rp1; \
\
/* Use the UCS4 table for single byte. */ \
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (cp = __ucs4_to_ibm930sb[ch + rp1->idx], \
__builtin_expect (cp[0], L'\1') == L'\0' && ch != '\0')) \
{ \
/* Use the UCS4 table for double byte. */ \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (cp = __ucs4_to_ibm930db[ch + rp2->idx], \
__builtin_expect (cp[0], L'\1')==L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
} \
else \
{ \
if (curcs == init || curcs == sb) \
{ \
if (__builtin_expect (outptr+1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SO; \
curcs = db; \
} \
\
if (__builtin_expect (outptr + 2 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = cp[0]; \
*outptr++ = cp[1]; \
} \
} \
else \
{ \
if (curcs == db) \
{ \
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SI; \
} \
\
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
if (ch == 0x7e) \
*outptr++ = 0xa1; \
else if (ch == 0x5c) \
*outptr++ = 0x5b; \
else \
*outptr++ = cp[0]; \
curcs = sb; \
} \
\
/* Now that we wrote the output increment the input pointer. */ \
inptr += 4; \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Now define the toplevel functions. */
#include <iconv/skeleton.c>

7748
iconvdata/ibm930.h Normal file

File diff suppressed because it is too large Load diff

263
iconvdata/ibm933.c Normal file
View file

@ -0,0 +1,263 @@
/* Conversion from and to IBM933.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
#include <stdint.h>
#include <wchar.h>
#include <byteswap.h>
#include "ibm933.h"
/* The shift sequences for this charset (it does not use ESC). */
#define SI 0x0F /* Shift In, host code to turn DBCS off. */
#define SO 0x0E /* Shift Out, host code to turn DBCS on. */
/* Definitions used in the body of the `gconv' function. */
#define CHARSET_NAME "IBM933//"
#define FROM_LOOP from_ibm933
#define TO_LOOP to_ibm933
/* Definitions of initialization and destructor function. */
#define DEFINE_INIT 1
#define DEFINE_FINI 1
#define MIN_NEEDED_FROM 1
#define MIN_NEEDED_TO 4
/* Current codeset type. */
enum
{
init = 0,
sb,
db
};
/* First, define the conversion function from IBM-933 to UCS4. */
#define MIN_NEEDED_INPUT MIN_NEEDED_FROM
#define MIN_NEEDED_OUTPUT MIN_NEEDED_TO
#define INIT_PARAMS int curcs = init;
#define LOOPFCT FROM_LOOP
#define BODY \
{ \
uint32_t ch = *inptr; \
uint32_t res; \
const struct gap *rp1 = __ibm933sb_to_ucs4_idx; \
const struct gap *rp2 = __ibm933db_to_ucs4_idx; \
\
if (__builtin_expect (ch, 0) == SO) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift OUT, change to DBCS converter. */ \
if (curcs == db) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = db; \
++inptr; \
ch = *inptr; \
} \
else if (__builtin_expect (ch, 0) == SI) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift IN, change to SBCS converter. */ \
if (curcs == sb) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = sb; \
++inptr; \
ch = *inptr; \
} \
\
if (curcs == sb || curcs == init) \
{ \
/* Use the IBM933 table for single byte. */ \
while (ch > rp1->end) \
++rp1; \
\
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (res = __ibm933sb_to_ucs4[ch + rp1->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
++inptr; \
continue; \
} \
else \
{ \
put32 (outptr, res); \
outptr += 4; \
++inptr; \
} \
} \
else if (curcs == db) \
{ \
/* Use the IBM933 table for double byte. */ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
/* The second character is not available. Store the \
intermediate result. */ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
ch = (ch * 0x100) + inptr[1]; \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (res = __ibm933db_to_ucs4[ch + rp2->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
inptr += 2; \
continue; \
} \
else \
{ \
put32 (outptr, res); \
outptr += 4; \
inptr += 2; \
} \
} \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Next, define the other direction. */
#define MIN_NEEDED_INPUT MIN_NEEDED_TO
#define MIN_NEEDED_OUTPUT MIN_NEEDED_FROM
#define INIT_PARAMS int curcs = init;
#define LOOPFCT TO_LOOP
#define BODY \
{ \
uint32_t ch = get32 (inptr); \
const struct gap *rp1 = __ucs4_to_ibm933sb_idx; \
const struct gap *rp2 = __ucs4_to_ibm933db_idx; \
const char *cp; \
\
if (__builtin_expect (ch, 0) >= 0xffff) \
{ \
rp1 = NULL; \
rp2 = NULL; \
} \
else \
while (ch > rp1->end) \
++rp1; \
\
/* Use the UCS4 table for single byte. */ \
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (cp = __ucs4_to_ibm933sb[ch + rp1->idx], \
__builtin_expect (cp[0], L'\1') == L'\0' && ch != '\0')) \
{ \
/* Use the UCS4 table for double byte. */ \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (cp = __ucs4_to_ibm933db[ch + rp2->idx], \
__builtin_expect (cp[0], L'\1')==L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
} \
else \
{ \
if (curcs == init || curcs == sb) \
{ \
if (__builtin_expect (outptr+1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SO; \
curcs = db; \
} \
\
if (__builtin_expect (outptr + 2 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = cp[0]; \
*outptr++ = cp[1]; \
} \
} \
else \
{ \
if (curcs == db) \
{ \
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SI; \
} \
\
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = cp[0]; \
curcs = sb; \
} \
\
/* Now that we wrote the output increment the input pointer. */ \
inptr += 4; \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Now define the toplevel functions. */
#include <iconv/skeleton.c>

10510
iconvdata/ibm933.h Normal file

File diff suppressed because it is too large Load diff

263
iconvdata/ibm935.c Normal file
View file

@ -0,0 +1,263 @@
/* Conversion from and to IBM935
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
#include <stdint.h>
#include <wchar.h>
#include <byteswap.h>
#include "ibm935.h"
/* The shift sequences for this charset (it does not use ESC). */
#define SI 0x0F /* Shift In, host code to turn DBCS off. */
#define SO 0x0E /* Shift Out, host code to turn DBCS on. */
/* Definitions used in the body of the `gconv' function. */
#define CHARSET_NAME "IBM935//"
#define FROM_LOOP from_ibm935
#define TO_LOOP to_ibm935
/* Definitions of initialization and destructor function. */
#define DEFINE_INIT 1
#define DEFINE_FINI 1
#define MIN_NEEDED_FROM 1
#define MIN_NEEDED_TO 4
/* Current codeset type. */
enum
{
init = 0,
sb,
db
};
/* First, define the conversion function from IBM-935 to UCS4. */
#define MIN_NEEDED_INPUT MIN_NEEDED_FROM
#define MIN_NEEDED_OUTPUT MIN_NEEDED_TO
#define INIT_PARAMS int curcs = init;
#define LOOPFCT FROM_LOOP
#define BODY \
{ \
uint32_t ch = *inptr; \
uint32_t res; \
const struct gap *rp1 = __ibm935sb_to_ucs4_idx; \
const struct gap *rp2 = __ibm935db_to_ucs4_idx; \
\
if (__builtin_expect(ch, 0) == SO) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift OUT, change to DBCS converter. */ \
if (curcs == db) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = db; \
++inptr; \
ch = *inptr; \
} \
else if (__builtin_expect (ch, 0) == SI) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift IN, change to SBCS converter. */ \
if (curcs == sb) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = sb; \
++inptr; \
ch = *inptr; \
} \
\
if (curcs == sb || curcs == init) \
{ \
/* Use the IBM935 table for single byte. */ \
while (ch > rp1->end) \
++rp1; \
\
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (res = __ibm935sb_to_ucs4[ch + rp1->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
++inptr; \
continue; \
} \
else \
{ \
put32 (outptr, res); \
outptr += 4; \
inptr++; \
} \
} \
else if (curcs == db) \
{ \
/* Use the IBM935 table for double byte. */ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
/* The second character is not available. \
Store the intermediate result. */ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
ch = (ch * 0x100) + inptr[1]; \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (res = __ibm935db_to_ucs4[ch + rp2->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
inptr += 2; \
continue; \
} \
else \
{ \
put32 (outptr, res); \
outptr += 4; \
inptr += 2; \
} \
} \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Next, define the other direction. */
#define MIN_NEEDED_INPUT MIN_NEEDED_TO
#define MIN_NEEDED_OUTPUT MIN_NEEDED_FROM
#define INIT_PARAMS int curcs = init;
#define LOOPFCT TO_LOOP
#define BODY \
{ \
uint32_t ch = get32 (inptr); \
const struct gap *rp1 = __ucs4_to_ibm935sb_idx; \
const struct gap *rp2 = __ucs4_to_ibm935db_idx; \
const char *cp; \
\
if (__builtin_expect (ch, 0) >= 0xffff) \
{ \
rp1 = NULL; \
rp2 = NULL; \
} \
else \
while (ch > rp1->end) \
++rp1; \
\
/* Use the UCS4 table for single byte. */ \
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (cp = __ucs4_to_ibm935sb[ch + rp1->idx], \
__builtin_expect (cp[0], L'\1') == L'\0' && ch != '\0')) \
{ \
/* Use the UCS4 table for double byte. */ \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (cp = __ucs4_to_ibm935db[ch + rp2->idx], \
__builtin_expect (cp[0], L'\1')==L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
} \
else \
{ \
if (curcs == init || curcs == sb) \
{ \
if (__builtin_expect (outptr+1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SO; \
curcs = db; \
} \
\
if (__builtin_expect (outptr + 2 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = cp[0]; \
*outptr++ = cp[1]; \
} \
} \
else \
{ \
if (curcs == db) \
{ \
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SI; \
} \
\
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = cp[0]; \
curcs = sb; \
} \
\
/* Now that we wrote the output increment the input pointer. */ \
inptr += 4; \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Now define the toplevel functions. */
#include <iconv/skeleton.c>

6531
iconvdata/ibm935.h Normal file

File diff suppressed because it is too large Load diff

213
iconvdata/ibm937.c Normal file
View file

@ -0,0 +1,213 @@
/* Conversion to and from IBM937.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
#include <stdint.h>
#include <wchar.h>
#include <byteswap.h>
#include "ibm937.h"
/* The shift sequences for this charset (it does not use ESC). */
#define SI 0x0F /* Shift In, host code to turn DBCS off. */
#define SO 0x0E /* Shift Out, host code to turn DBCS on. */
/* Definitions used in the body of the `gconv' function. */
#define CHARSET_NAME "IBM937//"
#define FROM_LOOP from_ibm937
#define TO_LOOP to_ibm937
/* Definitions of initialization and destructor function. */
#define DEFINE_INIT 1
#define DEFINE_FINI 1
#define MIN_NEEDED_FROM 1
#define MIN_NEEDED_TO 4
/* Current codeset type. */
enum
{
init = 0,
sb,
db
};
/* First, define the conversion function from IBM-937 to UCS4. */
#define MIN_NEEDED_INPUT MIN_NEEDED_FROM
#define MIN_NEEDED_OUTPUT MIN_NEEDED_TO
#define INIT_PARAMS int curcs = init;
#define LOOPFCT FROM_LOOP
#define BODY \
{ \
uint32_t ch = *inptr; \
\
if (__builtin_expect (ch, 0) == SO) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift OUT, change to DBCS converter. */ \
if (curcs == db) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = db; \
++inptr; \
ch = *inptr; \
} \
else if (__builtin_expect (ch, 0) == SI) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift IN, change to SBCS converter. */ \
if (curcs == sb) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = sb; \
++inptr; \
ch = *inptr; \
} \
\
if (curcs == sb || curcs == init) \
{ \
/* Use the UCS4 table for single byte. */ \
ch = __ibm937sb_to_ucs4[ch]; \
if (__builtin_expect (ch, L'\1') == L'\0' && *inptr != '\0') \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
++inptr; \
continue; \
} \
else \
{ \
put32 (outptr, ch); \
outptr += 4; \
inptr++; \
} \
} \
else if (curcs == db) \
{ \
/* Use the IBM937 table for double byte. */ \
ch = ibm937db_to_ucs4(inptr[0], inptr[1]); \
if (__builtin_expect (ch, L'\1') == L'\0' && *inptr != '\0') \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
inptr += 2; \
continue; \
} \
else \
{ \
put32 (outptr, ch); \
outptr += 4; \
inptr += 2; \
} \
} \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Next, define the other direction. */
#define MIN_NEEDED_INPUT MIN_NEEDED_TO
#define MIN_NEEDED_OUTPUT MIN_NEEDED_FROM
#define INIT_PARAMS int curcs = init;
#define LOOPFCT TO_LOOP
#define BODY \
{ \
uint32_t ch = get32 (inptr); \
const char *cp; \
\
/* Use the UCS4 table for single byte. */ \
cp = __ucs4_to_ibm937sb[ch]; \
if (__builtin_expect (ch >= sizeof (__ucs4_to_ibm937sb) \
/ sizeof (__ucs4_to_ibm937sb[0]), 0) \
|| (__builtin_expect (cp[0], '\1') == '\0' && ch != 0)) \
{ \
/* Use the UCS4 table for double byte. */ \
cp = __ucs4_to_ibm937db[ch]; \
if (__builtin_expect (cp[0], '\1') == '\0' && ch != 0) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
} \
else \
{ \
if (curcs == init || curcs == sb) \
{ \
*outptr++ = SO; \
if (__builtin_expect (outptr == outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
curcs = db; \
} \
*outptr++ = cp[0]; \
*outptr++ = cp[1]; \
} \
} \
else \
{ \
if (curcs == db) \
{ \
*outptr++ = SI; \
if (__builtin_expect (outptr == outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
} \
curcs = sb; \
*outptr++ = cp[0]; \
} \
\
/* Now that we wrote the output increment the input pointer. */ \
inptr += 4; \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Now define the toplevel functions. */
#include <iconv/skeleton.c>

11914
iconvdata/ibm937.h Normal file

File diff suppressed because it is too large Load diff

270
iconvdata/ibm939.c Normal file
View file

@ -0,0 +1,270 @@
/* Conversion to and from IBM939.
Copyright (C) 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Masahide Washizawa <washi@yamato.ibm.co.jp>, 2000.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the GNU C Library; see the file COPYING.LIB. If not,
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
#include <stdint.h>
#include <wchar.h>
#include <byteswap.h>
#include "ibm939.h"
/* The shift sequences for this charset (it does not use ESC). */
#define SI 0x0F /* Shift In, host code to turn DBCS off. */
#define SO 0x0E /* Shift Out, host code to turn DBCS on. */
/* Definitions used in the body of the `gconv' function. */
#define CHARSET_NAME "IBM939//"
#define FROM_LOOP from_ibm939
#define TO_LOOP to_ibm939
/* Definitions of initialization and destructor function. */
#define DEFINE_INIT 1
#define DEFINE_FINI 1
#define MIN_NEEDED_FROM 1
#define MIN_NEEDED_TO 4
/* Current codeset type. */
enum
{
init = 0,
sb,
db
};
/* First, define the conversion function from IBM-939 to UCS4. */
#define MIN_NEEDED_INPUT MIN_NEEDED_FROM
#define MIN_NEEDED_OUTPUT MIN_NEEDED_TO
#define INIT_PARAMS int curcs = init;
#define LOOPFCT FROM_LOOP
#define BODY \
{ \
uint32_t ch = *inptr; \
uint32_t res; \
const struct gap *rp1 = __ibm939sb_to_ucs4_idx; \
const struct gap *rp2 = __ibm939db_to_ucs4_idx; \
\
if (__builtin_expect (ch, 0) == SO) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift OUT, change to DBCS converter. */ \
if (curcs == db) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = db; \
++inptr; \
ch = *inptr; \
} \
else if (__builtin_expect (ch, 0) == SI) \
{ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
/* Shift IN, change to SBCS converter. */ \
if (curcs == sb) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
curcs = sb; \
++inptr; \
ch = *inptr; \
} \
\
if (curcs == sb || curcs == init) \
{ \
/* Use the IBM939 table for single byte. */ \
while (ch > rp1->end) \
++rp1; \
\
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (res = __ibm939sb_to_ucs4[ch + rp1->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
++inptr; \
continue; \
} \
else \
{ \
if (res == 0xa5) \
res = 0x5c; \
put32 (outptr, res); \
outptr += 4; \
++inptr; \
} \
} \
else if (curcs == db) \
{ \
/* Use the IBM939 table for double byte. */ \
if (__builtin_expect (inptr + 1 >= inend, 0)) \
{ \
/* The second character is not available. Store the \
intermediate result. */ \
result = __GCONV_INCOMPLETE_INPUT; \
break; \
} \
\
ch = (ch * 0x100) + inptr[1]; \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (res = __ibm939db_to_ucs4[ch + rp2->idx], \
__builtin_expect (res, L'\1') == L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
inptr += 2; \
continue; \
} \
else \
{ \
put32 (outptr, res); \
outptr += 4; \
inptr += 2; \
} \
} \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Next, define the other direction */
#define MIN_NEEDED_INPUT MIN_NEEDED_TO
#define MIN_NEEDED_OUTPUT MIN_NEEDED_FROM
#define INIT_PARAMS int curcs = init;
#define LOOPFCT TO_LOOP
#define BODY \
{ \
uint32_t ch = get32 (inptr); \
const struct gap *rp1 = __ucs4_to_ibm939sb_idx; \
const struct gap *rp2 = __ucs4_to_ibm939db_idx; \
const char *cp; \
\
if (__builtin_expect (ch, 0) >= 0xffff) \
{ \
rp1 = NULL; \
rp2 = NULL; \
} \
else \
while (ch > rp1->end) \
++rp1; \
\
/* Use the UCS4 table for single byte. */ \
if (__builtin_expect (rp1 == NULL, 0) \
|| __builtin_expect (ch < rp1->start, 0) \
|| (cp = __ucs4_to_ibm939sb[ch + rp1->idx], \
__builtin_expect (cp[0], L'\1') == L'\0' && ch != '\0')) \
{ \
/* Use the UCS4 table for double byte. */ \
while (ch > rp2->end) \
++rp2; \
\
if (__builtin_expect (rp2 == NULL, 0) \
|| __builtin_expect (ch < rp2->start, 0) \
|| (cp = __ucs4_to_ibm939db[ch + rp2->idx], \
__builtin_expect (cp[0], L'\1')==L'\0' && ch != '\0')) \
{ \
/* This is an illegal character. */ \
if (! ignore_errors_p ()) \
{ \
result = __GCONV_ILLEGAL_INPUT; \
break; \
} \
++*irreversible; \
} \
else \
{ \
if (curcs == init || curcs == sb) \
{ \
if (__builtin_expect (outptr+1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SO; \
curcs = db; \
} \
\
if (__builtin_expect (outptr + 2 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = cp[0]; \
*outptr++ = cp[1]; \
} \
} \
else \
{ \
if (curcs == db) \
{ \
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
*outptr++ = SI; \
} \
\
if (__builtin_expect (outptr + 1 > outend, 0)) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
if (ch == 0x7e) \
*outptr++ = 0xa0; \
else if (ch == 0x5c) \
*outptr++ = 0xb2; \
else \
*outptr++ = cp[0]; \
curcs = sb; \
} \
\
/* Now that we wrote the output increment the input pointer. */ \
inptr += 4; \
}
#define LOOP_NEED_FLAGS
#include <iconv/loop.c>
/* Now define the toplevel functions. */
#include <iconv/skeleton.c>

7748
iconvdata/ibm939.h Normal file

File diff suppressed because it is too large Load diff