| Index: source/common/locmap.c
|
| diff --git a/source/common/locmap.c b/source/common/locmap.c
|
| index 224a2b179a2498caf0f79b6323f5ee202bb99557..67a5f0d38a14cce2ae52a1862b6cbbe4f1acc43d 100644
|
| --- a/source/common/locmap.c
|
| +++ b/source/common/locmap.c
|
| @@ -1,6 +1,8 @@
|
| +// Copyright (C) 2016 and later: Unicode, Inc. and others.
|
| +// License & terms of use: http://www.unicode.org/copyright.html
|
| /*
|
| **********************************************************************
|
| - * Copyright (C) 1996-2014, International Business Machines
|
| + * Copyright (C) 1996-2016, International Business Machines
|
| * Corporation and others. All Rights Reserved.
|
| **********************************************************************
|
| *
|
| @@ -29,7 +31,6 @@
|
| #include "cstring.h"
|
| #include "cmemory.h"
|
|
|
| -#if 0
|
| #if U_PLATFORM == U_PF_WINDOWS && defined(_MSC_VER) && (_MSC_VER >= 1500)
|
| /*
|
| * TODO: It seems like we should widen this to
|
| @@ -41,7 +42,6 @@
|
| */
|
| #define USE_WINDOWS_LOCALE_API
|
| #endif
|
| -#endif
|
|
|
| #ifdef USE_WINDOWS_LOCALE_API
|
| #include <windows.h>
|
| @@ -115,7 +115,7 @@ static const ILcidPosixElement locmap_ ## id [] =
|
| * @param _posixID the full POSIX ID for this entry.
|
| */
|
| #define ILCID_POSIX_MAP(_posixID) \
|
| - {sizeof(locmap_ ## _posixID)/sizeof(ILcidPosixElement), locmap_ ## _posixID}
|
| + {UPRV_LENGTHOF(locmap_ ## _posixID), locmap_ ## _posixID}
|
|
|
| /*
|
| ////////////////////////////////////////////
|
| @@ -198,7 +198,8 @@ ILCID_POSIX_SUBTABLE(bn) {
|
| ILCID_POSIX_SUBTABLE(bo) {
|
| {0x51, "bo"},
|
| {0x0851, "bo_BT"},
|
| - {0x0451, "bo_CN"}
|
| + {0x0451, "bo_CN"},
|
| + {0x0c51, "dz_BT"}
|
| };
|
|
|
| ILCID_POSIX_ELEMENT_ARRAY(0x047e, br, br_FR)
|
| @@ -281,6 +282,7 @@ ILCID_POSIX_SUBTABLE(es) {
|
| {0x340a, "es_CL"},
|
| {0x240a, "es_CO"},
|
| {0x140a, "es_CR"},
|
| + {0x5c0a, "es_CU"},
|
| {0x1c0a, "es_DO"},
|
| {0x300a, "es_EC"},
|
| {0x0c0a, "es_ES"}, /*Modern sort.*/
|
| @@ -320,7 +322,8 @@ ILCID_POSIX_SUBTABLE(fa_AF) {
|
| ILCID_POSIX_SUBTABLE(ff) {
|
| {0x67, "ff"},
|
| {0x7c67, "ff_Latn"},
|
| - {0x0867, "ff_Latn_SN"}
|
| + {0x0867, "ff_Latn_SN"},
|
| + {0x0467, "ff_NG"}
|
| };
|
|
|
| ILCID_POSIX_ELEMENT_ARRAY(0x040b, fi, fi_FI)
|
| @@ -554,7 +557,35 @@ ILCID_POSIX_SUBTABLE(qu) {
|
| {0x0C6b, "quz_PE"}
|
| };
|
|
|
| -ILCID_POSIX_ELEMENT_ARRAY(0x0486, qut, qut_GT) /* qut is an ISO-639-3 code */
|
| +ILCID_POSIX_SUBTABLE(quc) {
|
| + {0x93, "quc"},
|
| + {0x0493, "quc_CO"},
|
| + /*
|
| + "quc_Latn_GT" is an exceptional case. Language ID of "quc"
|
| + is 0x93, but LCID of "quc_Latn_GT" is 0x486, which should be
|
| + under the group of "qut". "qut" is a retired ISO 639-3 language
|
| + code for West Central Quiche, and merged to "quc".
|
| + It looks Windows previously reserved "qut" for K'iche', but,
|
| + decided to use "quc" when adding a locale for K'iche' (Guatemala).
|
| +
|
| + This data structure used here assumes language ID bits in
|
| + LCID is unique for alphabetic language code. But this is not true
|
| + for "quc_Latn_GT". If we don't have the data below, LCID look up
|
| + by alphabetic locale ID (POSIX) will fail. The same entry is found
|
| + under "qut" below, which is required for reverse look up.
|
| + */
|
| + {0x0486, "quc_Latn_GT"}
|
| +};
|
| +
|
| +ILCID_POSIX_SUBTABLE(qut) {
|
| + {0x86, "qut"},
|
| + {0x0486, "qut_GT"},
|
| + /*
|
| + See the note in "quc" above.
|
| + */
|
| + {0x0486, "quc_Latn_GT"}
|
| +};
|
| +
|
| ILCID_POSIX_ELEMENT_ARRAY(0x0417, rm, rm_CH)
|
|
|
| ILCID_POSIX_SUBTABLE(ro) {
|
| @@ -580,6 +611,7 @@ ILCID_POSIX_ELEMENT_ARRAY(0x0485, sah,sah_RU)
|
| ILCID_POSIX_SUBTABLE(sd) {
|
| {0x59, "sd"},
|
| {0x0459, "sd_IN"},
|
| + {0x0459, "sd_Deva_IN"},
|
| {0x0859, "sd_PK"}
|
| };
|
|
|
| @@ -662,6 +694,7 @@ ILCID_POSIX_SUBTABLE(tzm) {
|
| {0x7c5f, "tzm_Latn"},
|
| {0x085f, "tzm_Latn_DZ"},
|
| {0x105f, "tzm_Tfng_MA"},
|
| + {0x045f, "tzm_Arab_MA"},
|
| {0x045f, "tmz"}
|
| };
|
|
|
| @@ -830,6 +863,7 @@ static const ILcidPosixMap gPosixIDmap[] = {
|
| ILCID_POSIX_MAP(ps), /* ps Pashto 0x63 */
|
| ILCID_POSIX_MAP(pt), /* pt Portuguese 0x16 */
|
| ILCID_POSIX_MAP(qu), /* qu Quechua 0x6B */
|
| + ILCID_POSIX_MAP(quc), /* quc K'iche 0x93 */
|
| ILCID_POSIX_MAP(qut), /* qut K'iche 0x86 */
|
| ILCID_POSIX_MAP(rm), /* rm Raeto-Romance/Romansh 0x17 */
|
| ILCID_POSIX_MAP(ro), /* ro Romanian 0x18 */
|
| @@ -876,7 +910,7 @@ static const ILcidPosixMap gPosixIDmap[] = {
|
| ILCID_POSIX_MAP(zu), /* zu Zulu 0x35 */
|
| };
|
|
|
| -static const uint32_t gLocaleCount = sizeof(gPosixIDmap)/sizeof(ILcidPosixMap);
|
| +static const uint32_t gLocaleCount = UPRV_LENGTHOF(gPosixIDmap);
|
|
|
| /**
|
| * Do not call this function. It is called by hostID.
|
| @@ -990,7 +1024,7 @@ uprv_convertToPosix(uint32_t hostid, char *posixID, int32_t posixIDCapacity, UEr
|
| int32_t tmpLen = 0;
|
| char locName[157]; /* ULOC_FULLNAME_CAPACITY */
|
|
|
| - tmpLen = GetLocaleInfoA(hostid, LOCALE_SNAME, (LPSTR)locName, sizeof(locName)/sizeof(locName[0]));
|
| + tmpLen = GetLocaleInfoA(hostid, LOCALE_SNAME, (LPSTR)locName, UPRV_LENGTHOF(locName));
|
| if (tmpLen > 1) {
|
| /* Windows locale name may contain sorting variant, such as "es-ES_tradnl".
|
| In such case, we need special mapping data found in the hardcoded table
|
|
|