| Index: source/i18n/locdspnm.cpp
|
| diff --git a/source/i18n/locdspnm.cpp b/source/i18n/locdspnm.cpp
|
| deleted file mode 100644
|
| index c0934cd5dc816b6205736c4fe593138312d7d613..0000000000000000000000000000000000000000
|
| --- a/source/i18n/locdspnm.cpp
|
| +++ /dev/null
|
| @@ -1,1012 +0,0 @@
|
| -/*
|
| -*******************************************************************************
|
| -* Copyright (C) 2010-2014, International Business Machines Corporation and
|
| -* others. All Rights Reserved.
|
| -*******************************************************************************
|
| -*/
|
| -
|
| -#include "unicode/utypes.h"
|
| -
|
| -#if !UCONFIG_NO_FORMATTING
|
| -
|
| -#include "unicode/locdspnm.h"
|
| -#include "unicode/msgfmt.h"
|
| -#include "unicode/ures.h"
|
| -#include "unicode/udisplaycontext.h"
|
| -#include "unicode/brkiter.h"
|
| -
|
| -#include "cmemory.h"
|
| -#include "cstring.h"
|
| -#include "mutex.h"
|
| -#include "ulocimp.h"
|
| -#include "umutex.h"
|
| -#include "ureslocs.h"
|
| -#include "uresimp.h"
|
| -
|
| -#include <stdarg.h>
|
| -
|
| -/**
|
| - * Concatenate a number of null-terminated strings to buffer, leaving a
|
| - * null-terminated string. The last argument should be the null pointer.
|
| - * Return the length of the string in the buffer, not counting the trailing
|
| - * null. Return -1 if there is an error (buffer is null, or buflen < 1).
|
| - */
|
| -static int32_t ncat(char *buffer, uint32_t buflen, ...) {
|
| - va_list args;
|
| - char *str;
|
| - char *p = buffer;
|
| - const char* e = buffer + buflen - 1;
|
| -
|
| - if (buffer == NULL || buflen < 1) {
|
| - return -1;
|
| - }
|
| -
|
| - va_start(args, buflen);
|
| - while ((str = va_arg(args, char *))) {
|
| - char c;
|
| - while (p != e && (c = *str++)) {
|
| - *p++ = c;
|
| - }
|
| - }
|
| - *p = 0;
|
| - va_end(args);
|
| -
|
| - return p - buffer;
|
| -}
|
| -
|
| -U_NAMESPACE_BEGIN
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -// Access resource data for locale components.
|
| -// Wrap code in uloc.c for now.
|
| -class ICUDataTable {
|
| - const char* path;
|
| - Locale locale;
|
| -
|
| -public:
|
| - ICUDataTable(const char* path, const Locale& locale);
|
| - ~ICUDataTable();
|
| -
|
| - const Locale& getLocale();
|
| -
|
| - UnicodeString& get(const char* tableKey, const char* itemKey,
|
| - UnicodeString& result) const;
|
| - UnicodeString& get(const char* tableKey, const char* subTableKey, const char* itemKey,
|
| - UnicodeString& result) const;
|
| -
|
| - UnicodeString& getNoFallback(const char* tableKey, const char* itemKey,
|
| - UnicodeString &result) const;
|
| - UnicodeString& getNoFallback(const char* tableKey, const char* subTableKey, const char* itemKey,
|
| - UnicodeString &result) const;
|
| -};
|
| -
|
| -inline UnicodeString &
|
| -ICUDataTable::get(const char* tableKey, const char* itemKey, UnicodeString& result) const {
|
| - return get(tableKey, NULL, itemKey, result);
|
| -}
|
| -
|
| -inline UnicodeString &
|
| -ICUDataTable::getNoFallback(const char* tableKey, const char* itemKey, UnicodeString& result) const {
|
| - return getNoFallback(tableKey, NULL, itemKey, result);
|
| -}
|
| -
|
| -ICUDataTable::ICUDataTable(const char* path, const Locale& locale)
|
| - : path(NULL), locale(Locale::getRoot())
|
| -{
|
| - if (path) {
|
| - int32_t len = uprv_strlen(path);
|
| - this->path = (const char*) uprv_malloc(len + 1);
|
| - if (this->path) {
|
| - uprv_strcpy((char *)this->path, path);
|
| - this->locale = locale;
|
| - }
|
| - }
|
| -}
|
| -
|
| -ICUDataTable::~ICUDataTable() {
|
| - if (path) {
|
| - uprv_free((void*) path);
|
| - path = NULL;
|
| - }
|
| -}
|
| -
|
| -const Locale&
|
| -ICUDataTable::getLocale() {
|
| - return locale;
|
| -}
|
| -
|
| -UnicodeString &
|
| -ICUDataTable::get(const char* tableKey, const char* subTableKey, const char* itemKey,
|
| - UnicodeString &result) const {
|
| - UErrorCode status = U_ZERO_ERROR;
|
| - int32_t len = 0;
|
| -
|
| - const UChar *s = uloc_getTableStringWithFallback(path, locale.getName(),
|
| - tableKey, subTableKey, itemKey,
|
| - &len, &status);
|
| - if (U_SUCCESS(status) && len > 0) {
|
| - return result.setTo(s, len);
|
| - }
|
| - return result.setTo(UnicodeString(itemKey, -1, US_INV));
|
| -}
|
| -
|
| -UnicodeString &
|
| -ICUDataTable::getNoFallback(const char* tableKey, const char* subTableKey, const char* itemKey,
|
| - UnicodeString& result) const {
|
| - UErrorCode status = U_ZERO_ERROR;
|
| - int32_t len = 0;
|
| -
|
| - const UChar *s = uloc_getTableStringWithFallback(path, locale.getName(),
|
| - tableKey, subTableKey, itemKey,
|
| - &len, &status);
|
| - if (U_SUCCESS(status)) {
|
| - return result.setTo(s, len);
|
| - }
|
| -
|
| - result.setToBogus();
|
| - return result;
|
| -}
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -LocaleDisplayNames::~LocaleDisplayNames() {}
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -#if 0 // currently unused
|
| -
|
| -class DefaultLocaleDisplayNames : public LocaleDisplayNames {
|
| - UDialectHandling dialectHandling;
|
| -
|
| -public:
|
| - // constructor
|
| - DefaultLocaleDisplayNames(UDialectHandling dialectHandling);
|
| -
|
| - virtual ~DefaultLocaleDisplayNames();
|
| -
|
| - virtual const Locale& getLocale() const;
|
| - virtual UDialectHandling getDialectHandling() const;
|
| -
|
| - virtual UnicodeString& localeDisplayName(const Locale& locale,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& localeDisplayName(const char* localeId,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& languageDisplayName(const char* lang,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& scriptDisplayName(const char* script,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& scriptDisplayName(UScriptCode scriptCode,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& regionDisplayName(const char* region,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& variantDisplayName(const char* variant,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& keyDisplayName(const char* key,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& keyValueDisplayName(const char* key,
|
| - const char* value,
|
| - UnicodeString& result) const;
|
| -};
|
| -
|
| -DefaultLocaleDisplayNames::DefaultLocaleDisplayNames(UDialectHandling dialectHandling)
|
| - : dialectHandling(dialectHandling) {
|
| -}
|
| -
|
| -DefaultLocaleDisplayNames::~DefaultLocaleDisplayNames() {
|
| -}
|
| -
|
| -const Locale&
|
| -DefaultLocaleDisplayNames::getLocale() const {
|
| - return Locale::getRoot();
|
| -}
|
| -
|
| -UDialectHandling
|
| -DefaultLocaleDisplayNames::getDialectHandling() const {
|
| - return dialectHandling;
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::localeDisplayName(const Locale& locale,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(locale.getName(), -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::localeDisplayName(const char* localeId,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(localeId, -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::languageDisplayName(const char* lang,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(lang, -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::scriptDisplayName(const char* script,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(script, -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::scriptDisplayName(UScriptCode scriptCode,
|
| - UnicodeString& result) const {
|
| - const char* name = uscript_getName(scriptCode);
|
| - if (name) {
|
| - return result = UnicodeString(name, -1, US_INV);
|
| - }
|
| - return result.remove();
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::regionDisplayName(const char* region,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(region, -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::variantDisplayName(const char* variant,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(variant, -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::keyDisplayName(const char* key,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(key, -1, US_INV);
|
| -}
|
| -
|
| -UnicodeString&
|
| -DefaultLocaleDisplayNames::keyValueDisplayName(const char* /* key */,
|
| - const char* value,
|
| - UnicodeString& result) const {
|
| - return result = UnicodeString(value, -1, US_INV);
|
| -}
|
| -
|
| -#endif // currently unused class DefaultLocaleDisplayNames
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -class LocaleDisplayNamesImpl : public LocaleDisplayNames {
|
| - Locale locale;
|
| - UDialectHandling dialectHandling;
|
| - ICUDataTable langData;
|
| - ICUDataTable regionData;
|
| - MessageFormat *separatorFormat;
|
| - MessageFormat *format;
|
| - MessageFormat *keyTypeFormat;
|
| - UDisplayContext capitalizationContext;
|
| - BreakIterator* capitalizationBrkIter;
|
| - static UMutex capitalizationBrkIterLock;
|
| - UnicodeString formatOpenParen;
|
| - UnicodeString formatReplaceOpenParen;
|
| - UnicodeString formatCloseParen;
|
| - UnicodeString formatReplaceCloseParen;
|
| - UDisplayContext nameLength;
|
| -
|
| - // Constants for capitalization context usage types.
|
| - enum CapContextUsage {
|
| - kCapContextUsageLanguage,
|
| - kCapContextUsageScript,
|
| - kCapContextUsageTerritory,
|
| - kCapContextUsageVariant,
|
| - kCapContextUsageKey,
|
| - kCapContextUsageKeyValue,
|
| - kCapContextUsageCount
|
| - };
|
| - // Capitalization transforms. For each usage type, indicates whether to titlecase for
|
| - // the context specified in capitalizationContext (which we know at construction time)
|
| - UBool fCapitalization[kCapContextUsageCount];
|
| -
|
| -public:
|
| - // constructor
|
| - LocaleDisplayNamesImpl(const Locale& locale, UDialectHandling dialectHandling);
|
| - LocaleDisplayNamesImpl(const Locale& locale, UDisplayContext *contexts, int32_t length);
|
| - virtual ~LocaleDisplayNamesImpl();
|
| -
|
| - virtual const Locale& getLocale() const;
|
| - virtual UDialectHandling getDialectHandling() const;
|
| - virtual UDisplayContext getContext(UDisplayContextType type) const;
|
| -
|
| - virtual UnicodeString& localeDisplayName(const Locale& locale,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& localeDisplayName(const char* localeId,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& languageDisplayName(const char* lang,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& scriptDisplayName(const char* script,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& scriptDisplayName(UScriptCode scriptCode,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& regionDisplayName(const char* region,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& variantDisplayName(const char* variant,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& keyDisplayName(const char* key,
|
| - UnicodeString& result) const;
|
| - virtual UnicodeString& keyValueDisplayName(const char* key,
|
| - const char* value,
|
| - UnicodeString& result) const;
|
| -private:
|
| - UnicodeString& localeIdName(const char* localeId,
|
| - UnicodeString& result) const;
|
| - UnicodeString& appendWithSep(UnicodeString& buffer, const UnicodeString& src) const;
|
| - UnicodeString& adjustForUsageAndContext(CapContextUsage usage, UnicodeString& result) const;
|
| - void initialize(void);
|
| -};
|
| -
|
| -UMutex LocaleDisplayNamesImpl::capitalizationBrkIterLock = U_MUTEX_INITIALIZER;
|
| -
|
| -LocaleDisplayNamesImpl::LocaleDisplayNamesImpl(const Locale& locale,
|
| - UDialectHandling dialectHandling)
|
| - : dialectHandling(dialectHandling)
|
| - , langData(U_ICUDATA_LANG, locale)
|
| - , regionData(U_ICUDATA_REGION, locale)
|
| - , separatorFormat(NULL)
|
| - , format(NULL)
|
| - , keyTypeFormat(NULL)
|
| - , capitalizationContext(UDISPCTX_CAPITALIZATION_NONE)
|
| - , capitalizationBrkIter(NULL)
|
| - , nameLength(UDISPCTX_LENGTH_FULL)
|
| -{
|
| - initialize();
|
| -}
|
| -
|
| -LocaleDisplayNamesImpl::LocaleDisplayNamesImpl(const Locale& locale,
|
| - UDisplayContext *contexts, int32_t length)
|
| - : dialectHandling(ULDN_STANDARD_NAMES)
|
| - , langData(U_ICUDATA_LANG, locale)
|
| - , regionData(U_ICUDATA_REGION, locale)
|
| - , separatorFormat(NULL)
|
| - , format(NULL)
|
| - , keyTypeFormat(NULL)
|
| - , capitalizationContext(UDISPCTX_CAPITALIZATION_NONE)
|
| - , capitalizationBrkIter(NULL)
|
| - , nameLength(UDISPCTX_LENGTH_FULL)
|
| -{
|
| - while (length-- > 0) {
|
| - UDisplayContext value = *contexts++;
|
| - UDisplayContextType selector = (UDisplayContextType)((uint32_t)value >> 8);
|
| - switch (selector) {
|
| - case UDISPCTX_TYPE_DIALECT_HANDLING:
|
| - dialectHandling = (UDialectHandling)value;
|
| - break;
|
| - case UDISPCTX_TYPE_CAPITALIZATION:
|
| - capitalizationContext = value;
|
| - break;
|
| - case UDISPCTX_TYPE_DISPLAY_LENGTH:
|
| - nameLength = value;
|
| - break;
|
| - default:
|
| - break;
|
| - }
|
| - }
|
| - initialize();
|
| -}
|
| -
|
| -void
|
| -LocaleDisplayNamesImpl::initialize(void) {
|
| - LocaleDisplayNamesImpl *nonConstThis = (LocaleDisplayNamesImpl *)this;
|
| - nonConstThis->locale = langData.getLocale() == Locale::getRoot()
|
| - ? regionData.getLocale()
|
| - : langData.getLocale();
|
| -
|
| - UnicodeString sep;
|
| - langData.getNoFallback("localeDisplayPattern", "separator", sep);
|
| - if (sep.isBogus()) {
|
| - sep = UnicodeString("{0}, {1}", -1, US_INV);
|
| - }
|
| - UErrorCode status = U_ZERO_ERROR;
|
| - separatorFormat = new MessageFormat(sep, status);
|
| -
|
| - UnicodeString pattern;
|
| - langData.getNoFallback("localeDisplayPattern", "pattern", pattern);
|
| - if (pattern.isBogus()) {
|
| - pattern = UnicodeString("{0} ({1})", -1, US_INV);
|
| - }
|
| - format = new MessageFormat(pattern, status);
|
| - if (pattern.indexOf((UChar)0xFF08) >= 0) {
|
| - formatOpenParen.setTo((UChar)0xFF08); // fullwidth (
|
| - formatReplaceOpenParen.setTo((UChar)0xFF3B); // fullwidth [
|
| - formatCloseParen.setTo((UChar)0xFF09); // fullwidth )
|
| - formatReplaceCloseParen.setTo((UChar)0xFF3D); // fullwidth ]
|
| - } else {
|
| - formatOpenParen.setTo((UChar)0x0028); // (
|
| - formatReplaceOpenParen.setTo((UChar)0x005B); // [
|
| - formatCloseParen.setTo((UChar)0x0029); // )
|
| - formatReplaceCloseParen.setTo((UChar)0x005D); // ]
|
| - }
|
| -
|
| - UnicodeString ktPattern;
|
| - langData.get("localeDisplayPattern", "keyTypePattern", ktPattern);
|
| - if (ktPattern.isBogus()) {
|
| - ktPattern = UnicodeString("{0}={1}", -1, US_INV);
|
| - }
|
| - keyTypeFormat = new MessageFormat(ktPattern, status);
|
| -
|
| - uprv_memset(fCapitalization, 0, sizeof(fCapitalization));
|
| -#if !UCONFIG_NO_BREAK_ITERATION
|
| - // The following is basically copied from DateFormatSymbols::initializeData
|
| - typedef struct {
|
| - const char * usageName;
|
| - LocaleDisplayNamesImpl::CapContextUsage usageEnum;
|
| - } ContextUsageNameToEnum;
|
| - const ContextUsageNameToEnum contextUsageTypeMap[] = {
|
| - // Entries must be sorted by usageTypeName; entry with NULL name terminates list.
|
| - { "key", kCapContextUsageKey },
|
| - { "keyValue", kCapContextUsageKeyValue },
|
| - { "languages", kCapContextUsageLanguage },
|
| - { "script", kCapContextUsageScript },
|
| - { "territory", kCapContextUsageTerritory },
|
| - { "variant", kCapContextUsageVariant },
|
| - { NULL, (CapContextUsage)0 },
|
| - };
|
| - // Only get the context data if we need it! This is a const object so we know now...
|
| - // Also check whether we will need a break iterator (depends on the data)
|
| - UBool needBrkIter = FALSE;
|
| - if (capitalizationContext == UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU || capitalizationContext == UDISPCTX_CAPITALIZATION_FOR_STANDALONE) {
|
| - int32_t len = 0;
|
| - UResourceBundle *localeBundle = ures_open(NULL, locale.getName(), &status);
|
| - if (U_SUCCESS(status)) {
|
| - UResourceBundle *contextTransforms = ures_getByKeyWithFallback(localeBundle, "contextTransforms", NULL, &status);
|
| - if (U_SUCCESS(status)) {
|
| - UResourceBundle *contextTransformUsage;
|
| - while ( (contextTransformUsage = ures_getNextResource(contextTransforms, NULL, &status)) != NULL ) {
|
| - const int32_t * intVector = ures_getIntVector(contextTransformUsage, &len, &status);
|
| - if (U_SUCCESS(status) && intVector != NULL && len >= 2) {
|
| - const char* usageKey = ures_getKey(contextTransformUsage);
|
| - if (usageKey != NULL) {
|
| - const ContextUsageNameToEnum * typeMapPtr = contextUsageTypeMap;
|
| - int32_t compResult = 0;
|
| - // linear search; list is short and we cannot be sure that bsearch is available
|
| - while ( typeMapPtr->usageName != NULL && (compResult = uprv_strcmp(usageKey, typeMapPtr->usageName)) > 0 ) {
|
| - ++typeMapPtr;
|
| - }
|
| - if (typeMapPtr->usageName != NULL && compResult == 0) {
|
| - int32_t titlecaseInt = (capitalizationContext == UDISPCTX_CAPITALIZATION_FOR_UI_LIST_OR_MENU)? intVector[0]: intVector[1];
|
| - if (titlecaseInt != 0) {
|
| - fCapitalization[typeMapPtr->usageEnum] = TRUE;;
|
| - needBrkIter = TRUE;
|
| - }
|
| - }
|
| - }
|
| - }
|
| - status = U_ZERO_ERROR;
|
| - ures_close(contextTransformUsage);
|
| - }
|
| - ures_close(contextTransforms);
|
| - }
|
| - ures_close(localeBundle);
|
| - }
|
| - }
|
| - // Get a sentence break iterator if we will need it
|
| - if (needBrkIter || capitalizationContext == UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE) {
|
| - status = U_ZERO_ERROR;
|
| - capitalizationBrkIter = BreakIterator::createSentenceInstance(locale, status);
|
| - if (U_FAILURE(status)) {
|
| - delete capitalizationBrkIter;
|
| - capitalizationBrkIter = NULL;
|
| - }
|
| - }
|
| -#endif
|
| -}
|
| -
|
| -LocaleDisplayNamesImpl::~LocaleDisplayNamesImpl() {
|
| - delete separatorFormat;
|
| - delete format;
|
| - delete keyTypeFormat;
|
| - delete capitalizationBrkIter;
|
| - }
|
| -
|
| -const Locale&
|
| -LocaleDisplayNamesImpl::getLocale() const {
|
| - return locale;
|
| -}
|
| -
|
| -UDialectHandling
|
| -LocaleDisplayNamesImpl::getDialectHandling() const {
|
| - return dialectHandling;
|
| -}
|
| -
|
| -UDisplayContext
|
| -LocaleDisplayNamesImpl::getContext(UDisplayContextType type) const {
|
| - switch (type) {
|
| - case UDISPCTX_TYPE_DIALECT_HANDLING:
|
| - return (UDisplayContext)dialectHandling;
|
| - case UDISPCTX_TYPE_CAPITALIZATION:
|
| - return capitalizationContext;
|
| - case UDISPCTX_TYPE_DISPLAY_LENGTH:
|
| - return nameLength;
|
| - default:
|
| - break;
|
| - }
|
| - return (UDisplayContext)0;
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::adjustForUsageAndContext(CapContextUsage usage,
|
| - UnicodeString& result) const {
|
| -#if !UCONFIG_NO_BREAK_ITERATION
|
| - // check to see whether we need to titlecase result
|
| - if ( result.length() > 0 && u_islower(result.char32At(0)) && capitalizationBrkIter!= NULL &&
|
| - ( capitalizationContext==UDISPCTX_CAPITALIZATION_FOR_BEGINNING_OF_SENTENCE || fCapitalization[usage] ) ) {
|
| - // note fCapitalization[usage] won't be set unless capitalizationContext is UI_LIST_OR_MENU or STANDALONE
|
| - Mutex lock(&capitalizationBrkIterLock);
|
| - result.toTitle(capitalizationBrkIter, locale, U_TITLECASE_NO_LOWERCASE | U_TITLECASE_NO_BREAK_ADJUSTMENT);
|
| - }
|
| -#endif
|
| - return result;
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::localeDisplayName(const Locale& locale,
|
| - UnicodeString& result) const {
|
| - UnicodeString resultName;
|
| -
|
| - const char* lang = locale.getLanguage();
|
| - if (uprv_strlen(lang) == 0) {
|
| - lang = "root";
|
| - }
|
| - const char* script = locale.getScript();
|
| - const char* country = locale.getCountry();
|
| - const char* variant = locale.getVariant();
|
| -
|
| - UBool hasScript = uprv_strlen(script) > 0;
|
| - UBool hasCountry = uprv_strlen(country) > 0;
|
| - UBool hasVariant = uprv_strlen(variant) > 0;
|
| -
|
| - if (dialectHandling == ULDN_DIALECT_NAMES) {
|
| - char buffer[ULOC_FULLNAME_CAPACITY];
|
| - do { // loop construct is so we can break early out of search
|
| - if (hasScript && hasCountry) {
|
| - ncat(buffer, ULOC_FULLNAME_CAPACITY, lang, "_", script, "_", country, (char *)0);
|
| - localeIdName(buffer, resultName);
|
| - if (!resultName.isBogus()) {
|
| - hasScript = FALSE;
|
| - hasCountry = FALSE;
|
| - break;
|
| - }
|
| - }
|
| - if (hasScript) {
|
| - ncat(buffer, ULOC_FULLNAME_CAPACITY, lang, "_", script, (char *)0);
|
| - localeIdName(buffer, resultName);
|
| - if (!resultName.isBogus()) {
|
| - hasScript = FALSE;
|
| - break;
|
| - }
|
| - }
|
| - if (hasCountry) {
|
| - ncat(buffer, ULOC_FULLNAME_CAPACITY, lang, "_", country, (char*)0);
|
| - localeIdName(buffer, resultName);
|
| - if (!resultName.isBogus()) {
|
| - hasCountry = FALSE;
|
| - break;
|
| - }
|
| - }
|
| - } while (FALSE);
|
| - }
|
| - if (resultName.isBogus() || resultName.isEmpty()) {
|
| - localeIdName(lang, resultName);
|
| - }
|
| -
|
| - UnicodeString resultRemainder;
|
| - UnicodeString temp;
|
| - StringEnumeration *e = NULL;
|
| - UErrorCode status = U_ZERO_ERROR;
|
| -
|
| - if (hasScript) {
|
| - resultRemainder.append(scriptDisplayName(script, temp));
|
| - }
|
| - if (hasCountry) {
|
| - appendWithSep(resultRemainder, regionDisplayName(country, temp));
|
| - }
|
| - if (hasVariant) {
|
| - appendWithSep(resultRemainder, variantDisplayName(variant, temp));
|
| - }
|
| - resultRemainder.findAndReplace(formatOpenParen, formatReplaceOpenParen);
|
| - resultRemainder.findAndReplace(formatCloseParen, formatReplaceCloseParen);
|
| -
|
| - e = locale.createKeywords(status);
|
| - if (e && U_SUCCESS(status)) {
|
| - UnicodeString temp2;
|
| - char value[ULOC_KEYWORD_AND_VALUES_CAPACITY]; // sigh, no ULOC_VALUE_CAPACITY
|
| - const char* key;
|
| - while ((key = e->next((int32_t *)0, status)) != NULL) {
|
| - locale.getKeywordValue(key, value, ULOC_KEYWORD_AND_VALUES_CAPACITY, status);
|
| - keyDisplayName(key, temp);
|
| - temp.findAndReplace(formatOpenParen, formatReplaceOpenParen);
|
| - temp.findAndReplace(formatCloseParen, formatReplaceCloseParen);
|
| - keyValueDisplayName(key, value, temp2);
|
| - temp2.findAndReplace(formatOpenParen, formatReplaceOpenParen);
|
| - temp2.findAndReplace(formatCloseParen, formatReplaceCloseParen);
|
| - if (temp2 != UnicodeString(value, -1, US_INV)) {
|
| - appendWithSep(resultRemainder, temp2);
|
| - } else if (temp != UnicodeString(key, -1, US_INV)) {
|
| - UnicodeString temp3;
|
| - Formattable data[] = {
|
| - temp,
|
| - temp2
|
| - };
|
| - FieldPosition fpos;
|
| - status = U_ZERO_ERROR;
|
| - keyTypeFormat->format(data, 2, temp3, fpos, status);
|
| - appendWithSep(resultRemainder, temp3);
|
| - } else {
|
| - appendWithSep(resultRemainder, temp)
|
| - .append((UChar)0x3d /* = */)
|
| - .append(temp2);
|
| - }
|
| - }
|
| - delete e;
|
| - }
|
| -
|
| - if (!resultRemainder.isEmpty()) {
|
| - Formattable data[] = {
|
| - resultName,
|
| - resultRemainder
|
| - };
|
| - FieldPosition fpos;
|
| - status = U_ZERO_ERROR;
|
| - format->format(data, 2, result, fpos, status);
|
| - return adjustForUsageAndContext(kCapContextUsageLanguage, result);
|
| - }
|
| -
|
| - result = resultName;
|
| - return adjustForUsageAndContext(kCapContextUsageLanguage, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::appendWithSep(UnicodeString& buffer, const UnicodeString& src) const {
|
| - if (buffer.isEmpty()) {
|
| - buffer.setTo(src);
|
| - } else {
|
| - UnicodeString combined;
|
| - Formattable data[] = {
|
| - buffer,
|
| - src
|
| - };
|
| - FieldPosition fpos;
|
| - UErrorCode status = U_ZERO_ERROR;
|
| - separatorFormat->format(data, 2, combined, fpos, status);
|
| - if (U_SUCCESS(status)) {
|
| - buffer.setTo(combined);
|
| - }
|
| - }
|
| - return buffer;
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::localeDisplayName(const char* localeId,
|
| - UnicodeString& result) const {
|
| - return localeDisplayName(Locale(localeId), result);
|
| -}
|
| -
|
| -// private
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::localeIdName(const char* localeId,
|
| - UnicodeString& result) const {
|
| - if (nameLength == UDISPCTX_LENGTH_SHORT) {
|
| - langData.getNoFallback("Languages%short", localeId, result);
|
| - if (!result.isBogus()) {
|
| - return result;
|
| - }
|
| - }
|
| - return langData.getNoFallback("Languages", localeId, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::languageDisplayName(const char* lang,
|
| - UnicodeString& result) const {
|
| - if (uprv_strcmp("root", lang) == 0 || uprv_strchr(lang, '_') != NULL) {
|
| - return result = UnicodeString(lang, -1, US_INV);
|
| - }
|
| - if (nameLength == UDISPCTX_LENGTH_SHORT) {
|
| - langData.get("Languages%short", lang, result);
|
| - if (!result.isBogus()) {
|
| - return adjustForUsageAndContext(kCapContextUsageLanguage, result);
|
| - }
|
| - }
|
| - langData.get("Languages", lang, result);
|
| - return adjustForUsageAndContext(kCapContextUsageLanguage, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::scriptDisplayName(const char* script,
|
| - UnicodeString& result) const {
|
| - if (nameLength == UDISPCTX_LENGTH_SHORT) {
|
| - langData.get("Scripts%short", script, result);
|
| - if (!result.isBogus()) {
|
| - return adjustForUsageAndContext(kCapContextUsageScript, result);
|
| - }
|
| - }
|
| - langData.get("Scripts", script, result);
|
| - return adjustForUsageAndContext(kCapContextUsageScript, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::scriptDisplayName(UScriptCode scriptCode,
|
| - UnicodeString& result) const {
|
| - return scriptDisplayName(uscript_getName(scriptCode), result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::regionDisplayName(const char* region,
|
| - UnicodeString& result) const {
|
| - if (nameLength == UDISPCTX_LENGTH_SHORT) {
|
| - regionData.get("Countries%short", region, result);
|
| - if (!result.isBogus()) {
|
| - return adjustForUsageAndContext(kCapContextUsageTerritory, result);
|
| - }
|
| - }
|
| - regionData.get("Countries", region, result);
|
| - return adjustForUsageAndContext(kCapContextUsageTerritory, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::variantDisplayName(const char* variant,
|
| - UnicodeString& result) const {
|
| - // don't have a resource for short variant names
|
| - langData.get("Variants", variant, result);
|
| - return adjustForUsageAndContext(kCapContextUsageVariant, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::keyDisplayName(const char* key,
|
| - UnicodeString& result) const {
|
| - // don't have a resource for short key names
|
| - langData.get("Keys", key, result);
|
| - return adjustForUsageAndContext(kCapContextUsageKey, result);
|
| -}
|
| -
|
| -UnicodeString&
|
| -LocaleDisplayNamesImpl::keyValueDisplayName(const char* key,
|
| - const char* value,
|
| - UnicodeString& result) const {
|
| - if (uprv_strcmp(key, "currency") == 0) {
|
| - // ICU4C does not have ICU4J CurrencyDisplayInfo equivalent for now.
|
| - UErrorCode sts = U_ZERO_ERROR;
|
| - UnicodeString ustrValue(value, -1, US_INV);
|
| - int32_t len;
|
| - UBool isChoice = FALSE;
|
| - const UChar *currencyName = ucurr_getName(ustrValue.getTerminatedBuffer(),
|
| - locale.getBaseName(), UCURR_LONG_NAME, &isChoice, &len, &sts);
|
| - if (U_FAILURE(sts)) {
|
| - // Return the value as is on failure
|
| - result = ustrValue;
|
| - return result;
|
| - }
|
| - result.setTo(currencyName, len);
|
| - return adjustForUsageAndContext(kCapContextUsageKeyValue, result);
|
| - }
|
| -
|
| - if (nameLength == UDISPCTX_LENGTH_SHORT) {
|
| - langData.get("Types%short", key, value, result);
|
| - if (!result.isBogus()) {
|
| - return adjustForUsageAndContext(kCapContextUsageKeyValue, result);
|
| - }
|
| - }
|
| - langData.get("Types", key, value, result);
|
| - return adjustForUsageAndContext(kCapContextUsageKeyValue, result);
|
| -}
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -LocaleDisplayNames*
|
| -LocaleDisplayNames::createInstance(const Locale& locale,
|
| - UDialectHandling dialectHandling) {
|
| - return new LocaleDisplayNamesImpl(locale, dialectHandling);
|
| -}
|
| -
|
| -LocaleDisplayNames*
|
| -LocaleDisplayNames::createInstance(const Locale& locale,
|
| - UDisplayContext *contexts, int32_t length) {
|
| - if (contexts == NULL) {
|
| - length = 0;
|
| - }
|
| - return new LocaleDisplayNamesImpl(locale, contexts, length);
|
| -}
|
| -
|
| -U_NAMESPACE_END
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -U_NAMESPACE_USE
|
| -
|
| -U_CAPI ULocaleDisplayNames * U_EXPORT2
|
| -uldn_open(const char * locale,
|
| - UDialectHandling dialectHandling,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (locale == NULL) {
|
| - locale = uloc_getDefault();
|
| - }
|
| - return (ULocaleDisplayNames *)LocaleDisplayNames::createInstance(Locale(locale), dialectHandling);
|
| -}
|
| -
|
| -U_CAPI ULocaleDisplayNames * U_EXPORT2
|
| -uldn_openForContext(const char * locale,
|
| - UDisplayContext *contexts, int32_t length,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (locale == NULL) {
|
| - locale = uloc_getDefault();
|
| - }
|
| - return (ULocaleDisplayNames *)LocaleDisplayNames::createInstance(Locale(locale), contexts, length);
|
| -}
|
| -
|
| -
|
| -U_CAPI void U_EXPORT2
|
| -uldn_close(ULocaleDisplayNames *ldn) {
|
| - delete (LocaleDisplayNames *)ldn;
|
| -}
|
| -
|
| -U_CAPI const char * U_EXPORT2
|
| -uldn_getLocale(const ULocaleDisplayNames *ldn) {
|
| - if (ldn) {
|
| - return ((const LocaleDisplayNames *)ldn)->getLocale().getName();
|
| - }
|
| - return NULL;
|
| -}
|
| -
|
| -U_CAPI UDialectHandling U_EXPORT2
|
| -uldn_getDialectHandling(const ULocaleDisplayNames *ldn) {
|
| - if (ldn) {
|
| - return ((const LocaleDisplayNames *)ldn)->getDialectHandling();
|
| - }
|
| - return ULDN_STANDARD_NAMES;
|
| -}
|
| -
|
| -U_CAPI UDisplayContext U_EXPORT2
|
| -uldn_getContext(const ULocaleDisplayNames *ldn,
|
| - UDisplayContextType type,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return (UDisplayContext)0;
|
| - }
|
| - return ((const LocaleDisplayNames *)ldn)->getContext(type);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_localeDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *locale,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || locale == NULL || (result == NULL && maxResultSize > 0) || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->localeDisplayName(locale, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_languageDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *lang,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || lang == NULL || (result == NULL && maxResultSize > 0) || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->languageDisplayName(lang, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_scriptDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *script,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || script == NULL || (result == NULL && maxResultSize > 0) || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->scriptDisplayName(script, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_scriptCodeDisplayName(const ULocaleDisplayNames *ldn,
|
| - UScriptCode scriptCode,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - return uldn_scriptDisplayName(ldn, uscript_getName(scriptCode), result, maxResultSize, pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_regionDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *region,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || region == NULL || (result == NULL && maxResultSize > 0) || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->regionDisplayName(region, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_variantDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *variant,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || variant == NULL || (result == NULL && maxResultSize > 0) || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->variantDisplayName(variant, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_keyDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *key,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || key == NULL || (result == NULL && maxResultSize > 0) || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->keyDisplayName(key, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -U_CAPI int32_t U_EXPORT2
|
| -uldn_keyValueDisplayName(const ULocaleDisplayNames *ldn,
|
| - const char *key,
|
| - const char *value,
|
| - UChar *result,
|
| - int32_t maxResultSize,
|
| - UErrorCode *pErrorCode) {
|
| - if (U_FAILURE(*pErrorCode)) {
|
| - return 0;
|
| - }
|
| - if (ldn == NULL || key == NULL || value == NULL || (result == NULL && maxResultSize > 0)
|
| - || maxResultSize < 0) {
|
| - *pErrorCode = U_ILLEGAL_ARGUMENT_ERROR;
|
| - return 0;
|
| - }
|
| - UnicodeString temp(result, 0, maxResultSize);
|
| - ((const LocaleDisplayNames *)ldn)->keyValueDisplayName(key, value, temp);
|
| - return temp.extract(result, maxResultSize, *pErrorCode);
|
| -}
|
| -
|
| -#endif
|
|
|