#include #include struct cp { DWORD id; char *name; char *enc; char *desc; }; static const struct cp cp_map[] = { { 37, "IBM037", "", "IBM EBCDIC US-Canada" }, { 437, "IBM437", "", "OEM United States" }, { 500, "IBM500", "", "IBM EBCDIC International" }, { 708, "ASMO-708", "", "Arabic (ASMO 708)" }, { 709, "", "", "Arabic (ASMO-449+, BCON V4)" }, { 710, "", "", "Arabic - Transparent Arabic" }, { 720, "DOS-720", "", "Arabic (Transparent ASMO); Arabic (DOS)" }, { 737, "ibm737", "", "OEM Greek (formerly 437G); Greek (DOS)" }, { 775, "ibm775", "", "OEM Baltic; Baltic (DOS)" }, { 850, "ibm850", "850|CP850|IBM850|CSPC850MULTILINGUAL", "OEM Multilingual Latin 1; Western European (DOS)" }, { 852, "ibm852", "", "OEM Latin 2; Central European (DOS)" }, { 855, "IBM855", "", "OEM Cyrillic (primarily Russian)" }, { 857, "ibm857", "", "OEM Turkish; Turkish (DOS)" }, { 858, "IBM00858", "", "OEM Multilingual Latin 1 + Euro symbol" }, { 860, "IBM860", "", "OEM Portuguese; Portuguese (DOS)" }, { 861, "ibm861", "", "OEM Icelandic; Icelandic (DOS)" }, { 862, "DOS-862", "862|CP862|IBM862|CSPC862LATINHEBREW", "OEM Hebrew; Hebrew (DOS)" }, { 863, "IBM863", "", "OEM French Canadian; French Canadian (DOS)" }, { 864, "IBM864", "", "OEM Arabic; Arabic (864)" }, { 865, "IBM865", "", "OEM Nordic; Nordic (DOS)" }, { 866, "cp866", "866|CP866|IBM866|CSIBM866", "OEM Russian; Cyrillic (DOS)" }, { 869, "ibm869", "", "OEM Modern Greek; Greek, Modern (DOS)" }, { 870, "IBM870", "", "IBM EBCDIC Multilingual/ROECE (Latin 2); IBM EBCDIC Multilingual Latin 2" }, { 874, "windows-874", "CP874", "ANSI/OEM Thai (ISO 8859-11); Thai (Windows)" }, { 875, "cp875", "", "IBM EBCDIC Greek Modern" }, { 932, "shift_jis", "CP932|SHIFT_JIS|MS_KANJI|CSSHIFTJIS", "ANSI/OEM Japanese; Japanese (Shift-JIS)" }, { 936, "gb2312", "GB2312|GBK|CP936|MS936|WINDOWS-936", "ANSI/OEM Simplified Chinese (PRC, Singapore); Chinese Simplified (GB2312)" }, { 949, "ks_c_5601-1987", "CP949|UHC", "ANSI/OEM Korean (Unified Hangul Code)" }, { 950, "big5", "CP950|BIG-5", "ANSI/OEM Traditional Chinese (Taiwan; Hong Kong SAR, PRC); Chinese Traditional (Big5)" }, { 1026, "IBM1026", "", "IBM EBCDIC Turkish (Latin 5)" }, { 1047, "IBM01047", "", "IBM EBCDIC Latin 1/Open System" }, { 1140, "IBM01140", "", "IBM EBCDIC US-Canada (037 + Euro symbol); IBM EBCDIC (US-Canada-Euro)" }, { 1141, "IBM01141", "", "IBM EBCDIC Germany (20273 + Euro symbol); IBM EBCDIC (Germany-Euro)" }, { 1142, "IBM01142", "", "IBM EBCDIC Denmark-Norway (20277 + Euro symbol); IBM EBCDIC (Denmark-Norway-Euro)" }, { 1143, "IBM01143", "", "IBM EBCDIC Finland-Sweden (20278 + Euro symbol); IBM EBCDIC (Finland-Sweden-Euro)" }, { 1144, "IBM01144", "", "IBM EBCDIC Italy (20280 + Euro symbol); IBM EBCDIC (Italy-Euro)" }, { 1145, "IBM01145", "", "IBM EBCDIC Latin America-Spain (20284 + Euro symbol); IBM EBCDIC (Spain-Euro)" }, { 1146, "IBM01146", "", "IBM EBCDIC United Kingdom (20285 + Euro symbol); IBM EBCDIC (UK-Euro)" }, { 1147, "IBM01147", "", "IBM EBCDIC France (20297 + Euro symbol); IBM EBCDIC (France-Euro)" }, { 1148, "IBM01148", "", "IBM EBCDIC International (500 + Euro symbol); IBM EBCDIC (International-Euro)" }, { 1149, "IBM01149", "", "IBM EBCDIC Icelandic (20871 + Euro symbol); IBM EBCDIC (Icelandic-Euro)" }, { 1200, "utf-16", "", "Unicode UTF-16, little endian byte order (BMP of ISO 10646); available only to managed applications" }, { 1201, "unicodeFFFE", "", "Unicode UTF-16, big endian byte order; available only to managed applications" }, { 1250, "windows-1250", "CP1250|MS-EE|WINDOWS-1250", "ANSI Central European; Central European (Windows)" }, { 1251, "windows-1251", "CP1251|MS-CYRL|WINDOWS-1251", "ANSI Cyrillic; Cyrillic (Windows)" }, { 1252, "windows-1252", "CP1252|MS-ANSI|WINDOWS-1252", "ANSI Latin 1; Western European (Windows)" }, { 1253, "windows-1253", "CP1253|MS-GREEK|WINDOWS-1253", "ANSI Greek; Greek (Windows)" }, { 1254, "windows-1254", "CP1254|MS-TURK|WINDOWS-1254", "ANSI Turkish; Turkish (Windows)" }, { 1255, "windows-1255", "CP1255|MS-HEBR|WINDOWS-1255", "ANSI Hebrew; Hebrew (Windows)" }, { 1256, "windows-1256", "CP1256|MS-ARAB|WINDOWS-1256", "ANSI Arabic; Arabic (Windows)" }, { 1257, "windows-1257", "CP1257|WINBALTRIM|WINDOWS-1257", "ANSI Baltic; Baltic (Windows)" }, { 1258, "windows-1258", "CP1258|WINDOWS-1258", "ANSI/OEM Vietnamese; Vietnamese (Windows)" }, { 1361, "Johab", "CP1361|JOHAB", "Korean (Johab)" }, { 10000, "macintosh", "MAC|MACINTOSH|MACROMAN|CSMACINTOSH", "MAC Roman; Western European (Mac)" }, { 10001, "x-mac-japanese", "", "Japanese (Mac)" }, { 10002, "x-mac-chinesetrad", "", "MAC Traditional Chinese (Big5); Chinese Traditional (Mac)" }, { 10003, "x-mac-korean", "", "Korean (Mac)" }, { 10004, "x-mac-arabic", "MACARABIC", "Arabic (Mac)" }, { 10005, "x-mac-hebrew", "MACHEBREW", "Hebrew (Mac)" }, { 10006, "x-mac-greek", "MACGREEK", "Greek (Mac)" }, { 10007, "x-mac-cyrillic", "MACCYRILLIC", "Cyrillic (Mac)" }, { 10008, "x-mac-chinesesimp", "", "MAC Simplified Chinese (GB 2312); Chinese Simplified (Mac)" }, { 10010, "x-mac-romanian", "MACROMANIA", "Romanian (Mac)" }, { 10017, "x-mac-ukrainian", "MACUKRAINE", "Ukrainian (Mac)" }, { 10021, "x-mac-thai", "MACTHAI", "Thai (Mac)" }, { 10029, "x-mac-ce", "MACCENTRALEUROPE", "MAC Latin 2; Central European (Mac)" }, { 10079, "x-mac-icelandic", "MACICELAND", "Icelandic (Mac)" }, { 10081, "x-mac-turkish", "MACTURKISH", "Turkish (Mac)" }, { 10082, "x-mac-croatian", "MACCROATIAN", "Croatian (Mac)" }, { 12000, "utf-32", "", "Unicode UTF-32, little endian byte order; available only to managed applications" }, { 12001, "utf-32BE", "", "Unicode UTF-32, big endian byte order; available only to managed applications" }, { 20000, "x-Chinese_CNS", "", "CNS Taiwan; Chinese Traditional (CNS)" }, { 20001, "x-cp20001", "", "TCA Taiwan" }, { 20002, "x_Chinese-Eten", "", "Eten Taiwan; Chinese Traditional (Eten)" }, { 20003, "x-cp20003", "", "IBM5550 Taiwan" }, { 20004, "x-cp20004", "", "TeleText Taiwan" }, { 20005, "x-cp20005", "", "Wang Taiwan" }, { 20105, "x-IA5", "", "IA5 (IRV International Alphabet No. 5, 7-bit); Western European (IA5)" }, { 20106, "x-IA5-German", "", "IA5 German (7-bit)" }, { 20107, "x-IA5-Swedish", "", "IA5 Swedish (7-bit)" }, { 20108, "x-IA5-Norwegian", "", "IA5 Norwegian (7-bit)" }, { 20127, "us-ascii", "", "US-ASCII (7-bit)" }, { 20261, "x-cp20261", "", "T.61" }, { 20269, "x-cp20269", "", "ISO 6937 Non-Spacing Accent" }, { 20273, "IBM273", "", "IBM EBCDIC Germany" }, { 20277, "IBM277", "", "IBM EBCDIC Denmark-Norway" }, { 20278, "IBM278", "", "IBM EBCDIC Finland-Sweden" }, { 20280, "IBM280", "", "IBM EBCDIC Italy" }, { 20284, "IBM284", "", "IBM EBCDIC Latin America-Spain" }, { 20285, "IBM285", "", "IBM EBCDIC United Kingdom" }, { 20290, "IBM290", "", "IBM EBCDIC Japanese Katakana Extended" }, { 20297, "IBM297", "", "IBM EBCDIC France" }, { 20420, "IBM420", "", "IBM EBCDIC Arabic" }, { 20423, "IBM423", "", "IBM EBCDIC Greek" }, { 20424, "IBM424", "", "IBM EBCDIC Hebrew" }, { 20833, "x-EBCDIC-KoreanExtended", "", "IBM EBCDIC Korean Extended" }, { 20838, "IBM-Thai", "", "IBM EBCDIC Thai" }, { 20866, "koi8-r", "KOI8-R|CSKOI8R", "Russian (KOI8-R); Cyrillic (KOI8-R)" }, { 20871, "IBM871", "", "IBM EBCDIC Icelandic" }, { 20880, "IBM880", "", "IBM EBCDIC Cyrillic Russian" }, { 20905, "IBM905", "", "IBM EBCDIC Turkish" }, { 20924, "IBM00924", "", "IBM EBCDIC Latin 1/Open System (1047 + Euro symbol)" }, { 20932, "EUC-JP", "EUC-JP|EUCJP|EXTENDED_UNIX_CODE_PACKED_FORMAT_FOR_JAPANESE|CSEUCPKDFMTJAPANESE", "Japanese (JIS 0208-1990 and 0212-1990)" }, { 20936, "x-cp20936", "", "Simplified Chinese (GB2312); Chinese Simplified (GB2312-80)" }, { 20949, "x-cp20949", "", "Korean Wansung" }, { 21025, "cp1025", "", "IBM EBCDIC Cyrillic Serbian-Bulgarian" }, /*{ 21027, "", "", "(deprecated)" },*/ { 21866, "koi8-u", "KOI8-U", "Ukrainian (KOI8-U); Cyrillic (KOI8-U)" }, { 28591, "iso-8859-1", "CP819|IBM819|ISO-8859-1|ISO-IR-100|ISO8859-1|ISO_8859-1|ISO_8859-1:1987|L1|LATIN1|CSISOLATIN1", "ISO 8859-1 Latin 1; Western European (ISO)" }, { 28592, "iso-8859-2", "ISO-8859-2|ISO-IR-101|ISO8859-2|ISO_8859-2|ISO_8859-2:1987|L2|LATIN2|CSISOLATIN2", "ISO 8859-2 Central European; Central European (ISO)" }, { 28593, "iso-8859-3", "ISO-8859-3|ISO-IR-109|ISO8859-3|ISO_8859-3|ISO_8859-3:1988|L3|LATIN3|CSISOLATIN3", "ISO 8859-3 Latin 3" }, { 28594, "iso-8859-4", "ISO-8859-4|ISO-IR-110|ISO8859-4|ISO_8859-4|ISO_8859-4:1988|L4|LATIN4|CSISOLATIN4", "ISO 8859-4 Baltic" }, { 28595, "iso-8859-5", "CYRILLIC|ISO-8859-5|ISO-IR-144|ISO8859-5|ISO_8859-5|ISO_8859-5:1988|CSISOLATINCYRILLIC", "ISO 8859-5 Cyrillic" }, { 28596, "iso-8859-6", "ARABIC|ASMO-708|ECMA-114|ISO-8859-6|ISO-IR-127|ISO8859-6|ISO_8859-6|ISO_8859-6:1987|CSISOLATINARABIC", "ISO 8859-6 Arabic" }, { 28597, "iso-8859-7", "ECMA-118|ELOT_928|GREEK|GREEK8|ISO-8859-7|ISO-IR-126|ISO8859-7|ISO_8859-7|ISO_8859-7:1987|ISO_8859-7:2003|CSISOLATINGREEK", "ISO 8859-7 Greek" }, { 28598, "iso-8859-8", "HEBREW|ISO-8859-8|ISO-IR-138|ISO8859-8|ISO_8859-8|ISO_8859-8:1988|CSISOLATINHEBREW", "ISO 8859-8 Hebrew; Hebrew (ISO-Visual)" }, { 28599, "iso-8859-9", "ISO-8859-9|ISO-IR-148|ISO8859-9|ISO_8859-9|ISO_8859-9:1989|L5|LATIN5|CSISOLATIN5", "ISO 8859-9 Turkish" }, { 28603, "iso-8859-13", "ISO-8859-13|ISO-IR-179|ISO8859-13|ISO_8859-13|L7|LATIN7", "ISO 8859-13 Estonian" }, { 28605, "iso-8859-15", "ISO-8859-15|ISO-IR-203|ISO8859-15|ISO_8859-15|ISO_8859-15:1998|LATIN-9", "ISO 8859-15 Latin 9" }, { 29001, "x-Europa", "", "Europa 3" }, { 38598, "iso-8859-8-i", "", "ISO 8859-8 Hebrew; Hebrew (ISO-Logical)" }, { 50220, "iso-2022-jp", "CP50220", "ISO 2022 Japanese with no halfwidth Katakana; Japanese (JIS)" }, { 50221, "csISO2022JP", "CP50221", "ISO 2022 Japanese with halfwidth Katakana; Japanese (JIS-Allow 1 byte Kana)" }, { 50222, "iso-2022-jp", "ISO-2022-JP|CP50222", "ISO 2022 Japanese JIS X 0201-1989; Japanese (JIS-Allow 1 byte Kana - SO/SI)" }, { 50225, "iso-2022-kr", "ISO-2022-KR|CSISO2022KR", "ISO 2022 Korean" }, { 50227, "x-cp50227", "", "ISO 2022 Simplified Chinese; Chinese Simplified (ISO 2022)" }, { 50229, "x-cp50229", "", "ISO 2022 Traditional Chinese" }, { 50930, "", "", "EBCDIC Japanese (Katakana) Extended" }, { 50931, "", "", "EBCDIC US-Canada and Japanese" }, { 50933, "", "", "EBCDIC Korean Extended and Korean" }, { 50935, "", "", "EBCDIC Simplified Chinese Extended and Simplified Chinese" }, { 50936, "", "", "EBCDIC Simplified Chinese" }, { 50937, "", "", "EBCDIC US-Canada and Traditional Chinese" }, { 50939, "", "", "EBCDIC Japanese (Latin) Extended and Japanese" }, { 51932, "euc-jp", "", "EUC Japanese" }, { 51936, "EUC-CN", "", "EUC Simplified Chinese; Chinese Simplified (EUC)" }, { 51949, "euc-kr", "EUC-KR|EUCKR|CSEUCKR", "EUC Korean" }, { 51950, "", "", "EUC Traditional Chinese" }, { 52936, "hz-gb-2312", "HZ|HZ-GB-2312", "HZ-GB2312 Simplified Chinese; Chinese Simplified (HZ)" }, { 54936, "GB18030", "GB18030|CSGB18030", "Windows XP and later: GB18030 Simplified Chinese (4 byte); Chinese Simplified (GB18030)" }, { 57002, "x-iscii-de", "", "ISCII Devanagari" }, { 57003, "x-iscii-be", "", "ISCII Bangla" }, { 57004, "x-iscii-ta", "", "ISCII Tamil" }, { 57005, "x-iscii-te", "", "ISCII Telugu" }, { 57006, "x-iscii-as", "", "ISCII Assamese" }, { 57007, "x-iscii-or", "", "ISCII Odia" }, { 57008, "x-iscii-ka", "", "ISCII Kannada" }, { 57009, "x-iscii-ma", "", "ISCII Malayalam" }, { 57010, "x-iscii-gu", "", "ISCII Gujarati" }, { 57011, "x-iscii-pa", "", "ISCII Punjabi" }, { 65000, "utf-7", "UTF-7", "Unicode (UTF-7)" }, { 65001, "utf-8", "UTF-8", "Unicode (UTF-8)" }, { 0, NULL, NULL }, }; int main(int argc, char **argv) { DWORD cp; CPINFOEX info; struct cp *cur; int rnd = 0; /*if (argc < 2) { printf("Usage: cpinfoex cp_id\n"); return 0; } cp = atoi(argv[1]);*/ #if 0 /* Ref: http://www.iana.org/assignments/character-sets/character-sets.xhtml https://msdn.microsoft.com/en-us/goglobal/bb964653 http://www.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/ */ #endif /* struct php_win32_cp { DWORD id; DWORD to_w_fl; DWORD from_w_fl; DWORD char_size; char *name; char *enc; char *desc; }; */ /*printf("struct php_win32_cp {\n\tDWORD id;\n\tDWORD to_w_fl;\n\tDWORD from_w_fl;\n\tDWORD char_size;\n\tchar *name;\n\tchar *enc;\n\tchar *desc;\n};\n\n"); */ printf("/* Autogenerated file. Update cp_enc_map_gen.c and regen like \n" " cp_enc_map_gen.exe > cp_enc_map.c \n*/\n\n"); printf("static const struct php_win32_cp php_win32_cp_map[] = {"); cur = &cp_map[0]; #ifdef ORDER_IT while (rnd <= 2 && ++rnd && (cur = &cp_map[0])) #endif while (cur->desc != NULL) { if (!IsValidCodePage(cur->id)) { #ifdef ORDER_IT if (2 == rnd) #endif printf("\t/* %u is invalid */\n", cur->id); //printf("#if 0\n\t{ %u, 0, \"%s\", \"%s\" },\n#endif\n", cur->id, cur->name, cur->desc); } else if (GetCPInfoEx(cur->id, 0, &info)) { DWORD to_w_fl = 0, from_w_fl = 0; if (65001U == cur->id || 54936U == cur->id) { from_w_fl = WC_ERR_INVALID_CHARS; to_w_fl = MB_ERR_INVALID_CHARS; } //printf("\t{ %u, %u, \"%s\", \"%s\" },\n", cur->id, info.MaxCharSize, cur->name, cur->desc); if (!cur->enc[0]) { #ifdef ORDER_IT if (2 == rnd) #endif //printf("\t/* { %u, %u, \"%s\", NULL, \"%s\" }, */\n", info.CodePage, info.MaxCharSize, cur->name, info.CodePageName); printf("\t{ %u, %u, %u, %u, \"%s\", NULL, \"%s\" },\n", info.CodePage, to_w_fl, from_w_fl, info.MaxCharSize, cur->name, info.CodePageName); } else { #ifdef ORDER_IT if (1 == rnd) #endif printf("\t{ %u, %u, %u, %u, \"%s\", \"%s\", \"%s\" },\n", info.CodePage, to_w_fl, from_w_fl, info.MaxCharSize, cur->name, cur->enc, info.CodePageName); } } cur++; } printf("};\n\n"); return 0; }