Index: icu46/source/i18n/locdspnm.cpp |
=================================================================== |
--- icu46/source/i18n/locdspnm.cpp (revision 0) |
+++ icu46/source/i18n/locdspnm.cpp (revision 0) |
@@ -0,0 +1,694 @@ |
+/* |
+******************************************************************************* |
+* Copyright (C) 2010, 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 "cmemory.h" |
+#include "cstring.h" |
+#include "ulocimp.h" |
+#include "ureslocs.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)) { |
+ 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; |
+} |
+ |
+//////////////////////////////////////////////////////////////////////////////////////////////////// |
+ |
+UOBJECT_DEFINE_NO_RTTI_IMPLEMENTATION(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; |
+ UnicodeString sep; |
+ MessageFormat *format; |
+ |
+public: |
+ // constructor |
+ LocaleDisplayNamesImpl(const Locale& locale, UDialectHandling dialectHandling); |
+ virtual ~LocaleDisplayNamesImpl(); |
+ |
+ 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; |
+private: |
+ UnicodeString& localeIdName(const char* localeId, |
+ UnicodeString& result) const; |
+ UnicodeString& appendWithSep(UnicodeString& buffer, const UnicodeString& src) const; |
+}; |
+ |
+LocaleDisplayNamesImpl::LocaleDisplayNamesImpl(const Locale& locale, |
+ UDialectHandling dialectHandling) |
+ : dialectHandling(dialectHandling) |
+ , langData(U_ICUDATA_LANG, locale) |
+ , regionData(U_ICUDATA_REGION, locale) |
+ , format(NULL) |
+{ |
+ LocaleDisplayNamesImpl *nonConstThis = (LocaleDisplayNamesImpl *)this; |
+ nonConstThis->locale = langData.getLocale() == Locale::getRoot() |
+ ? regionData.getLocale() |
+ : langData.getLocale(); |
+ |
+ langData.getNoFallback("localeDisplayPattern", "separator", sep); |
+ if (sep.isBogus()) { |
+ sep = UnicodeString(", ", -1, US_INV); |
+ } |
+ |
+ UnicodeString pattern; |
+ langData.getNoFallback("localeDisplayPattern", "pattern", pattern); |
+ if (pattern.isBogus()) { |
+ pattern = UnicodeString("{0} ({1})", -1, US_INV); |
+ } |
+ UErrorCode status = U_ZERO_ERROR; |
+ format = new MessageFormat(pattern, status); |
+} |
+ |
+LocaleDisplayNamesImpl::~LocaleDisplayNamesImpl() { |
+ delete format; |
+} |
+ |
+const Locale& |
+LocaleDisplayNamesImpl::getLocale() const { |
+ return locale; |
+} |
+ |
+UDialectHandling |
+LocaleDisplayNamesImpl::getDialectHandling() const { |
+ return dialectHandling; |
+} |
+ |
+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)); |
+ } |
+ |
+ 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); |
+ appendWithSep(resultRemainder, keyDisplayName(key, temp)) |
+ .append("=") |
+ .append(keyValueDisplayName(key, value, temp2)); |
+ } |
+ delete e; |
+ } |
+ |
+ if (!resultRemainder.isEmpty()) { |
+ Formattable data[] = { |
+ resultName, |
+ resultRemainder |
+ }; |
+ FieldPosition fpos; |
+ status = U_ZERO_ERROR; |
+ format->format(data, 2, result, fpos, status); |
+ return result; |
+ } |
+ |
+ return result = resultName; |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::appendWithSep(UnicodeString& buffer, const UnicodeString& src) const { |
+ if (!buffer.isEmpty()) { |
+ buffer.append(sep); |
+ } |
+ buffer.append(src); |
+ return buffer; |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::localeDisplayName(const char* localeId, |
+ UnicodeString& result) const { |
+ return localeDisplayName(Locale(localeId), result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::localeIdName(const char* localeId, |
+ UnicodeString& result) const { |
+ 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); |
+ } |
+ return langData.get("Languages", lang, result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::scriptDisplayName(const char* script, |
+ UnicodeString& result) const { |
+ return langData.get("Scripts", script, result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::scriptDisplayName(UScriptCode scriptCode, |
+ UnicodeString& result) const { |
+ const char* name = uscript_getName(scriptCode); |
+ return langData.get("Scripts", name, result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::regionDisplayName(const char* region, |
+ UnicodeString& result) const { |
+ return regionData.get("Countries", region, result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::variantDisplayName(const char* variant, |
+ UnicodeString& result) const { |
+ return langData.get("Variants", variant, result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::keyDisplayName(const char* key, |
+ UnicodeString& result) const { |
+ return langData.get("Keys", key, result); |
+} |
+ |
+UnicodeString& |
+LocaleDisplayNamesImpl::keyValueDisplayName(const char* key, |
+ const char* value, |
+ UnicodeString& result) const { |
+ return langData.get("Types", key, value, result); |
+} |
+ |
+//////////////////////////////////////////////////////////////////////////////////////////////////// |
+ |
+LocaleDisplayNames* |
+LocaleDisplayNames::createInstance(const Locale& locale, |
+ UDialectHandling dialectHandling) { |
+ return new LocaleDisplayNamesImpl(locale, dialectHandling); |
+} |
+ |
+U_NAMESPACE_END |
+ |
+//////////////////////////////////////////////////////////////////////////////////////////////////// |
+ |
+U_NAMESPACE_USE |
+ |
+U_DRAFT 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_DRAFT void U_EXPORT2 |
+uldn_close(ULocaleDisplayNames *ldn) { |
+ delete (LocaleDisplayNames *)ldn; |
+} |
+ |
+U_DRAFT const char * U_EXPORT2 |
+uldn_getLocale(const ULocaleDisplayNames *ldn) { |
+ if (ldn) { |
+ return ((const LocaleDisplayNames *)ldn)->getLocale().getName(); |
+ } |
+ return NULL; |
+} |
+ |
+U_DRAFT UDialectHandling U_EXPORT2 |
+uldn_getDialectHandling(const ULocaleDisplayNames *ldn) { |
+ if (ldn) { |
+ return ((const LocaleDisplayNames *)ldn)->getDialectHandling(); |
+ } |
+ return ULDN_STANDARD_NAMES; |
+} |
+ |
+U_DRAFT 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_DRAFT 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_DRAFT 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_DRAFT 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_DRAFT 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_DRAFT 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_DRAFT 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_DRAFT 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 |
Property changes on: icu46/source/i18n/locdspnm.cpp |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |