ICU-10260 Port J LocaleDisplayNamesImpl change for (->[ to C; make similar changes in uloc_getDisplayName

X-SVN-Rev: 34369
This commit is contained in:
Peter Edberg 2013-09-18 08:33:47 +00:00
parent cd3860a322
commit bb7e154629
3 changed files with 119 additions and 1 deletions

View File

@ -484,6 +484,11 @@ uloc_getDisplayName(const char *locale,
int32_t patLen = 0; int32_t patLen = 0;
int32_t sub0Pos, sub1Pos; int32_t sub0Pos, sub1Pos;
UChar formatOpenParen = 0x0028; // (
UChar formatReplaceOpenParen = 0x005B; // [
UChar formatCloseParen = 0x0029; // )
UChar formatReplaceCloseParen = 0x005D; // ]
UBool haveLang = TRUE; /* assume true, set false if we find we don't have UBool haveLang = TRUE; /* assume true, set false if we find we don't have
a lang component in the locale */ a lang component in the locale */
UBool haveRest = TRUE; /* assume true, set false if we find we don't have UBool haveRest = TRUE; /* assume true, set false if we find we don't have
@ -543,6 +548,7 @@ uloc_getDisplayName(const char *locale,
patLen=defaultPatLen; patLen=defaultPatLen;
sub0Pos=defaultSub0Pos; sub0Pos=defaultSub0Pos;
sub1Pos=defaultSub1Pos; sub1Pos=defaultSub1Pos;
// use default formatOpenParen etc. set above
} else { /* non-default pattern */ } else { /* non-default pattern */
UChar *p0=u_strstr(pattern, sub0); UChar *p0=u_strstr(pattern, sub0);
UChar *p1=u_strstr(pattern, sub1); UChar *p1=u_strstr(pattern, sub1);
@ -556,6 +562,12 @@ uloc_getDisplayName(const char *locale,
int32_t t=sub0Pos; sub0Pos=sub1Pos; sub1Pos=t; int32_t t=sub0Pos; sub0Pos=sub1Pos; sub1Pos=t;
langi=1; langi=1;
} }
if (u_strchr(pattern, 0xFF08) != NULL) {
formatOpenParen = 0xFF08; // fullwidth (
formatReplaceOpenParen = 0xFF3B; // fullwidth [
formatCloseParen = 0xFF09; // fullwidth )
formatReplaceCloseParen = 0xFF3D; // fullwidth ]
}
} }
/* We loop here because there is one case in which after the first pass we could need to /* We loop here because there is one case in which after the first pass we could need to
@ -677,7 +689,14 @@ uloc_getDisplayName(const char *locale,
if (len>0) { if (len>0) {
/* we addeed a component, so add separator and write it if there's room. */ /* we addeed a component, so add separator and write it if there's room. */
if(len+sepLen<=cap) { if(len+sepLen<=cap) {
p+=len; const UChar * plimit = p + len;
for (; p < plimit; p++) {
if (*p == formatOpenParen) {
*p = formatReplaceOpenParen;
} else if (*p == formatCloseParen) {
*p = formatReplaceCloseParen;
}
}
for(int32_t i=0;i<sepLen;++i) { for(int32_t i=0;i<sepLen;++i) {
*p++=separator[i]; *p++=separator[i];
} }

View File

@ -275,6 +275,10 @@ class LocaleDisplayNamesImpl : public LocaleDisplayNames {
MessageFormat *format; MessageFormat *format;
MessageFormat *keyTypeFormat; MessageFormat *keyTypeFormat;
UDisplayContext capitalizationContext; UDisplayContext capitalizationContext;
UnicodeString formatOpenParen;
UnicodeString formatReplaceOpenParen;
UnicodeString formatCloseParen;
UnicodeString formatReplaceCloseParen;
// Constants for capitalization context usage types. // Constants for capitalization context usage types.
enum CapContextUsage { enum CapContextUsage {
@ -389,6 +393,17 @@ LocaleDisplayNamesImpl::initialize(void) {
pattern = UnicodeString("{0} ({1})", -1, US_INV); pattern = UnicodeString("{0} ({1})", -1, US_INV);
} }
format = new MessageFormat(pattern, status); format = new MessageFormat(pattern, status);
if (pattern.indexOf((UChar)0xFF08) >= 0) {
formatOpenParen.setTo(0xFF08); // fullwidth (
formatReplaceOpenParen.setTo(0xFF3B); // fullwidth [
formatCloseParen.setTo(0xFF09); // fullwidth )
formatReplaceCloseParen.setTo(0xFF3D); // fullwidth ]
} else {
formatOpenParen.setTo(0x0028); // (
formatReplaceOpenParen.setTo(0x005B); // [
formatCloseParen.setTo(0x0029); // )
formatReplaceCloseParen.setTo(0x005D); // ]
}
UnicodeString ktPattern; UnicodeString ktPattern;
langData.get("localeDisplayPattern", "keyTypePattern", ktPattern); langData.get("localeDisplayPattern", "keyTypePattern", ktPattern);
@ -596,6 +611,8 @@ LocaleDisplayNamesImpl::localeDisplayName(const Locale& locale,
if (hasVariant) { if (hasVariant) {
appendWithSep(resultRemainder, variantDisplayName(variant, temp)); appendWithSep(resultRemainder, variantDisplayName(variant, temp));
} }
resultRemainder.findAndReplace(formatOpenParen, formatReplaceOpenParen);
resultRemainder.findAndReplace(formatCloseParen, formatReplaceCloseParen);
e = locale.createKeywords(status); e = locale.createKeywords(status);
if (e && U_SUCCESS(status)) { if (e && U_SUCCESS(status)) {
@ -605,7 +622,11 @@ LocaleDisplayNamesImpl::localeDisplayName(const Locale& locale,
while ((key = e->next((int32_t *)0, status)) != NULL) { while ((key = e->next((int32_t *)0, status)) != NULL) {
locale.getKeywordValue(key, value, ULOC_KEYWORD_AND_VALUES_CAPACITY, status); locale.getKeywordValue(key, value, ULOC_KEYWORD_AND_VALUES_CAPACITY, status);
keyDisplayName(key, temp); keyDisplayName(key, temp);
temp.findAndReplace(formatOpenParen, formatReplaceOpenParen);
temp.findAndReplace(formatCloseParen, formatReplaceCloseParen);
keyValueDisplayName(key, value, temp2); keyValueDisplayName(key, value, temp2);
temp2.findAndReplace(formatOpenParen, formatReplaceOpenParen);
temp2.findAndReplace(formatCloseParen, formatReplaceCloseParen);
if (temp2 != UnicodeString(value, -1, US_INV)) { if (temp2 != UnicodeString(value, -1, US_INV)) {
appendWithSep(resultRemainder, temp2); appendWithSep(resultRemainder, temp2);
} else if (temp != UnicodeString(key, -1, US_INV)) { } else if (temp != UnicodeString(key, -1, US_INV)) {

View File

@ -33,6 +33,7 @@
#include "unicode/ustring.h" #include "unicode/ustring.h"
#include "unicode/utypes.h" #include "unicode/utypes.h"
#include "unicode/ulocdata.h" #include "unicode/ulocdata.h"
#include "unicode/uldnames.h"
#include "unicode/parseerr.h" /* may not be included with some uconfig switches */ #include "unicode/parseerr.h" /* may not be included with some uconfig switches */
#include "udbgutil.h" #include "udbgutil.h"
#define LENGTHOF(array) (int32_t)(sizeof(array)/sizeof((array)[0])) #define LENGTHOF(array) (int32_t)(sizeof(array)/sizeof((array)[0]))
@ -41,6 +42,7 @@ static void TestNullDefault(void);
static void TestNonexistentLanguageExemplars(void); static void TestNonexistentLanguageExemplars(void);
static void TestLocDataErrorCodeChaining(void); static void TestLocDataErrorCodeChaining(void);
static void TestLanguageExemplarsFallbacks(void); static void TestLanguageExemplarsFallbacks(void);
static void TestDisplayNameBrackets(void);
static void TestUnicodeDefines(void); static void TestUnicodeDefines(void);
@ -245,6 +247,7 @@ void addLocaleTest(TestNode** root)
TESTCASE(TestTrailingNull); TESTCASE(TestTrailingNull);
TESTCASE(TestUnicodeDefines); TESTCASE(TestUnicodeDefines);
TESTCASE(TestEnglishExemplarCharacters); TESTCASE(TestEnglishExemplarCharacters);
TESTCASE(TestDisplayNameBrackets);
} }
@ -1021,6 +1024,81 @@ setUpDataTable();
cleanUpDataTable(); cleanUpDataTable();
} }
/*------------------------------
* TestDisplayNameBrackets
*/
typedef struct {
const char * displayLocale;
const char * namedRegion;
const char * namedLocale;
const char * regionName;
const char * localeName;
} DisplayNameBracketsItem;
static const DisplayNameBracketsItem displayNameBracketsItems[] = {
{ "en", "CC", "en_CC", "Cocos (Keeling) Islands", "English (Cocos [Keeling] Islands)" },
{ "en", "MM", "my_MM", "Myanmar (Burma)", "Burmese (Myanmar [Burma])" },
{ "en", "MM", "my_Mymr_MM", "Myanmar (Burma)", "Burmese (Myanmar, Myanmar [Burma])" },
{ "zh", "CC", "en_CC", "\\u79D1\\u79D1\\u65AF\\uFF08\\u57FA\\u6797\\uFF09\\u7FA4\\u5C9B", "\\u82F1\\u6587\\uFF08\\u79D1\\u79D1\\u65AF\\uFF3B\\u57FA\\u6797\\uFF3D\\u7FA4\\u5C9B\\uFF09" },
{ "zh", "CG", "fr_CG", "\\u521A\\u679C\\uFF08\\u5E03\\uFF09", "\\u6CD5\\u6587\\uFF08\\u521A\\u679C\\uFF3B\\u5E03\\uFF3D\\uFF09" },
{ NULL, NULL, NULL, NULL, NULL }
};
enum { kDisplayNameBracketsMax = 128 };
static void TestDisplayNameBrackets()
{
const DisplayNameBracketsItem * itemPtr = displayNameBracketsItems;
for (; itemPtr->displayLocale != NULL; itemPtr++) {
ULocaleDisplayNames * uldn;
UErrorCode status;
UChar expectRegionName[kDisplayNameBracketsMax];
UChar expectLocaleName[kDisplayNameBracketsMax];
UChar getName[kDisplayNameBracketsMax];
int32_t ulen;
(void) u_unescape(itemPtr->regionName, expectRegionName, kDisplayNameBracketsMax);
(void) u_unescape(itemPtr->localeName, expectLocaleName, kDisplayNameBracketsMax);
status = U_ZERO_ERROR;
ulen = uloc_getDisplayCountry(itemPtr->namedLocale, itemPtr->displayLocale, getName, kDisplayNameBracketsMax, &status);
if ( U_FAILURE(status) || u_strcmp(getName, expectRegionName) != 0 ) {
log_err("uloc_getDisplayCountry for displayLocale %s and namedLocale %s returns unexpected name or status %s\n", itemPtr->displayLocale, itemPtr->namedLocale, myErrorName(status));
}
status = U_ZERO_ERROR;
ulen = uloc_getDisplayName(itemPtr->namedLocale, itemPtr->displayLocale, getName, kDisplayNameBracketsMax, &status);
if ( U_FAILURE(status) || u_strcmp(getName, expectLocaleName) != 0 ) {
log_err("uloc_getDisplayName for displayLocale %s and namedLocale %s returns unexpected name or status %s\n", itemPtr->displayLocale, itemPtr->namedLocale, myErrorName(status));
}
status = U_ZERO_ERROR;
uldn = uldn_open(itemPtr->displayLocale, ULDN_STANDARD_NAMES, &status);
if (U_SUCCESS(status)) {
status = U_ZERO_ERROR;
ulen = uldn_regionDisplayName(uldn, itemPtr->namedRegion, getName, kDisplayNameBracketsMax, &status);
if ( U_FAILURE(status) || u_strcmp(getName, expectRegionName) != 0 ) {
log_err("uldn_regionDisplayName for displayLocale %s and namedRegion %s returns unexpected name or status %s\n", itemPtr->displayLocale, itemPtr->namedRegion, myErrorName(status));
}
status = U_ZERO_ERROR;
ulen = uldn_localeDisplayName(uldn, itemPtr->namedLocale, getName, kDisplayNameBracketsMax, &status);
if ( U_FAILURE(status) || u_strcmp(getName, expectLocaleName) != 0 ) {
log_err("uldn_localeDisplayName for displayLocale %s and namedLocale %s returns unexpected name or status %s\n", itemPtr->displayLocale, itemPtr->namedLocale, myErrorName(status));
}
uldn_close(uldn);
} else {
log_data_err("uldn_open fails for displayLocale %s, status=%s\n", itemPtr->displayLocale, u_errorName(status));
}
}
}
/*------------------------------
* TestISOFunctions
*/
#if !UCONFIG_NO_FILE_IO && !UCONFIG_NO_LEGACY_CONVERSION #if !UCONFIG_NO_FILE_IO && !UCONFIG_NO_LEGACY_CONVERSION
/* test for uloc_getISOLanguages, uloc_getISOCountries */ /* test for uloc_getISOLanguages, uloc_getISOCountries */
static void TestISOFunctions() static void TestISOFunctions()