diff options
Diffstat (limited to 'i18npool/source/localedata/localedata.cxx')
-rw-r--r-- | i18npool/source/localedata/localedata.cxx | 1470 |
1 files changed, 1470 insertions, 0 deletions
diff --git a/i18npool/source/localedata/localedata.cxx b/i18npool/source/localedata/localedata.cxx new file mode 100644 index 000000000000..920a63fe149a --- /dev/null +++ b/i18npool/source/localedata/localedata.cxx @@ -0,0 +1,1470 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_i18npool.hxx" + +#include <localedata.hxx> +#include <i18npool/mslangid.hxx> +#include <rtl/ustrbuf.hxx> +#include <string.h> +#include <stdio.h> +#include "rtl/instance.hxx" + +using namespace com::sun::star::i18n; +using namespace com::sun::star::uno; +using namespace com::sun::star::lang; +using namespace com::sun::star; +using namespace rtl; + +static const sal_Char clocaledata[] = "com.sun.star.i18n.LocaleData"; + +typedef sal_Unicode** (SAL_CALL * MyFunc_Type)( sal_Int16&); +typedef sal_Unicode*** (SAL_CALL * MyFunc_Type2)( sal_Int16&, sal_Int16& ); +typedef sal_Unicode**** (SAL_CALL * MyFunc_Type3)( sal_Int16&, sal_Int16&, sal_Int16& ); +typedef sal_Unicode const * const * (SAL_CALL * MyFunc_FormatCode)( sal_Int16&, sal_Unicode const *&, sal_Unicode const *& ); + +#ifdef OS2 // YD 8.3!! +static const char *lcl_DATA_EN = "ld_en"; +static const char *lcl_DATA_ES = "ld_es"; +static const char *lcl_DATA_EURO = "ld_eur"; +static const char *lcl_DATA_OTHERS = "ld_oth"; +#else +static const char *lcl_DATA_EN = "localedata_en"; +static const char *lcl_DATA_ES = "localedata_es"; +static const char *lcl_DATA_EURO = "localedata_euro"; +static const char *lcl_DATA_OTHERS = "localedata_others"; +#endif + +static const struct { + const char* pLocale; + const char* pLib; +} aLibTable[] = { + { "en_US", lcl_DATA_EN }, + { "en_AU", lcl_DATA_EN }, + { "en_BZ", lcl_DATA_EN }, + { "en_CA", lcl_DATA_EN }, + { "en_GB", lcl_DATA_EN }, + { "en_IE", lcl_DATA_EN }, + { "en_JM", lcl_DATA_EN }, + { "en_NZ", lcl_DATA_EN }, + { "en_PH", lcl_DATA_EN }, + { "en_TT", lcl_DATA_EN }, + { "en_ZA", lcl_DATA_EN }, + { "en_ZW", lcl_DATA_EN }, + { "en_NA", lcl_DATA_EN }, + { "en_GH", lcl_DATA_EN }, + + { "es_ES", lcl_DATA_ES }, + { "es_AR", lcl_DATA_ES }, + { "es_BO", lcl_DATA_ES }, + { "es_CL", lcl_DATA_ES }, + { "es_CO", lcl_DATA_ES }, + { "es_CR", lcl_DATA_ES }, + { "es_DO", lcl_DATA_ES }, + { "es_EC", lcl_DATA_ES }, + { "es_GT", lcl_DATA_ES }, + { "es_HN", lcl_DATA_ES }, + { "es_MX", lcl_DATA_ES }, + { "es_NI", lcl_DATA_ES }, + { "es_PA", lcl_DATA_ES }, + { "es_PE", lcl_DATA_ES }, + { "es_PR", lcl_DATA_ES }, + { "es_PY", lcl_DATA_ES }, + { "es_SV", lcl_DATA_ES }, + { "es_UY", lcl_DATA_ES }, + { "es_VE", lcl_DATA_ES }, + { "gl_ES", lcl_DATA_ES }, + + { "de_DE", lcl_DATA_EURO }, + { "de_AT", lcl_DATA_EURO }, + { "de_CH", lcl_DATA_EURO }, + { "de_LI", lcl_DATA_EURO }, + { "de_LU", lcl_DATA_EURO }, + { "fr_FR", lcl_DATA_EURO }, + { "fr_BE", lcl_DATA_EURO }, + { "fr_CA", lcl_DATA_EURO }, + { "fr_CH", lcl_DATA_EURO }, + { "fr_LU", lcl_DATA_EURO }, + { "fr_MC", lcl_DATA_EURO }, + { "it_IT", lcl_DATA_EURO }, + { "it_CH", lcl_DATA_EURO }, + { "sl_SI", lcl_DATA_EURO }, + { "sv_SE", lcl_DATA_EURO }, + { "sv_FI", lcl_DATA_EURO }, + { "ca_ES", lcl_DATA_EURO }, + { "cs_CZ", lcl_DATA_EURO }, + { "sk_SK", lcl_DATA_EURO }, + { "da_DK", lcl_DATA_EURO }, + { "el_GR", lcl_DATA_EURO }, + { "fi_FI", lcl_DATA_EURO }, + { "is_IS", lcl_DATA_EURO }, + { "nl_BE", lcl_DATA_EURO }, + { "nl_NL", lcl_DATA_EURO }, + { "no_NO", lcl_DATA_EURO }, + { "nn_NO", lcl_DATA_EURO }, + { "nb_NO", lcl_DATA_EURO }, + { "pl_PL", lcl_DATA_EURO }, + { "pt_BR", lcl_DATA_EURO }, + { "pt_PT", lcl_DATA_EURO }, + { "ru_RU", lcl_DATA_EURO }, + { "tr_TR", lcl_DATA_EURO }, + { "et_EE", lcl_DATA_EURO }, + { "lb_LU", lcl_DATA_EURO }, + { "lt_LT", lcl_DATA_EURO }, + { "lv_LV", lcl_DATA_EURO }, + { "uk_UA", lcl_DATA_EURO }, + { "ro_RO", lcl_DATA_EURO }, + { "cy_GB", lcl_DATA_EURO }, + { "bg_BG", lcl_DATA_EURO }, + { "sh_ME", lcl_DATA_EURO }, + { "sh_RS", lcl_DATA_EURO }, + { "sh_YU", lcl_DATA_EURO }, + { "sr_ME", lcl_DATA_EURO }, + { "sr_RS", lcl_DATA_EURO }, + { "sr_YU", lcl_DATA_EURO }, + { "hr_HR", lcl_DATA_EURO }, + { "bs_BA", lcl_DATA_EURO }, + { "eu", lcl_DATA_EURO }, + { "fo_FO", lcl_DATA_EURO }, + { "ga_IE", lcl_DATA_EURO }, + { "ka_GE", lcl_DATA_EURO }, + { "be_BY", lcl_DATA_EURO }, + { "kl_GL", lcl_DATA_EURO }, + { "mk_MK", lcl_DATA_EURO }, + { "br_FR", lcl_DATA_EURO }, + { "la_VA", lcl_DATA_EURO }, + { "cv_RU", lcl_DATA_EURO }, + { "wa_BE", lcl_DATA_EURO }, + { "fur_IT", lcl_DATA_EURO }, + { "gsc_FR", lcl_DATA_EURO }, + { "fy_NL", lcl_DATA_EURO }, + { "oc_FR", lcl_DATA_EURO }, + { "mt_MT", lcl_DATA_EURO }, + { "sc_IT", lcl_DATA_EURO }, + { "ast_ES", lcl_DATA_EURO }, + { "ltg_LV", lcl_DATA_EURO }, + { "hsb_DE", lcl_DATA_EURO }, + + { "ja_JP", lcl_DATA_OTHERS }, + { "ko_KR", lcl_DATA_OTHERS }, + { "zh_CN", lcl_DATA_OTHERS }, + { "zh_HK", lcl_DATA_OTHERS }, + { "zh_SG", lcl_DATA_OTHERS }, + { "zh_TW", lcl_DATA_OTHERS }, + { "zh_MO", lcl_DATA_OTHERS }, + + { "ar_EG", lcl_DATA_OTHERS }, + { "ar_LB", lcl_DATA_OTHERS }, + { "ar_SA", lcl_DATA_OTHERS }, + { "ar_TN", lcl_DATA_OTHERS }, + { "he_IL", lcl_DATA_OTHERS }, + { "hi_IN", lcl_DATA_OTHERS }, + { "kn_IN", lcl_DATA_OTHERS }, + { "ta_IN", lcl_DATA_OTHERS }, + { "te_IN", lcl_DATA_OTHERS }, + { "gu_IN", lcl_DATA_OTHERS }, + { "mr_IN", lcl_DATA_OTHERS }, + { "pa_IN", lcl_DATA_OTHERS }, + { "bn_IN", lcl_DATA_OTHERS }, + { "or_IN", lcl_DATA_OTHERS }, + { "en_IN", lcl_DATA_OTHERS }, + { "ml_IN", lcl_DATA_OTHERS }, + { "bn_BD", lcl_DATA_OTHERS }, + { "th_TH", lcl_DATA_OTHERS }, + + { "af_ZA", lcl_DATA_OTHERS }, + { "hu_HU", lcl_DATA_OTHERS }, + { "id_ID", lcl_DATA_OTHERS }, + { "ms_MY", lcl_DATA_OTHERS }, + { "ia", lcl_DATA_OTHERS }, + { "mn_MN", lcl_DATA_OTHERS }, + { "az_AZ", lcl_DATA_OTHERS }, + { "sw_TZ", lcl_DATA_OTHERS }, + { "km_KH", lcl_DATA_OTHERS }, + { "lo_LA", lcl_DATA_OTHERS }, + { "rw_RW", lcl_DATA_OTHERS }, + { "eo", lcl_DATA_OTHERS }, + { "dz_BT", lcl_DATA_OTHERS }, + { "ne_NP", lcl_DATA_OTHERS }, + { "zu_ZA", lcl_DATA_OTHERS }, + { "nso_ZA", lcl_DATA_OTHERS }, + { "vi_VN", lcl_DATA_OTHERS }, + { "tn_ZA", lcl_DATA_OTHERS }, + { "xh_ZA", lcl_DATA_OTHERS }, + { "st_ZA", lcl_DATA_OTHERS }, + { "ss_ZA", lcl_DATA_OTHERS }, + { "ve_ZA", lcl_DATA_OTHERS }, + { "nr_ZA", lcl_DATA_OTHERS }, + { "ts_ZA", lcl_DATA_OTHERS }, + { "ku_TR", lcl_DATA_OTHERS }, + { "ak_GH", lcl_DATA_OTHERS }, + { "af_NA", lcl_DATA_OTHERS }, + { "am_ET", lcl_DATA_OTHERS }, + { "ti_ER", lcl_DATA_OTHERS }, + { "tg_TJ", lcl_DATA_OTHERS }, + { "ky_KG", lcl_DATA_OTHERS }, + { "kk_KZ", lcl_DATA_OTHERS }, + { "fa_IR", lcl_DATA_OTHERS }, + { "ha_GH", lcl_DATA_OTHERS }, + { "ee_GH", lcl_DATA_OTHERS }, + { "sg_CF", lcl_DATA_OTHERS }, + { "lg_UG", lcl_DATA_OTHERS }, + { "uz_UZ", lcl_DATA_OTHERS }, + { "ln_CD", lcl_DATA_OTHERS }, + { "hy_AM", lcl_DATA_OTHERS }, + { "hil_PH", lcl_DATA_OTHERS }, + { "so_SO", lcl_DATA_OTHERS }, + { "gug_PY", lcl_DATA_OTHERS }, + { "tk_TM", lcl_DATA_OTHERS }, + { "my_MM", lcl_DATA_OTHERS }, + { "shs_CA", lcl_DATA_OTHERS }, + { "tpi_PG", lcl_DATA_OTHERS }, + { "ar_OM", lcl_DATA_OTHERS }, + { "ug_CN", lcl_DATA_OTHERS }, + { "om_ET", lcl_DATA_OTHERS }, + { "plt_MG", lcl_DATA_OTHERS }, +}; + +static const sal_Unicode under = sal_Unicode('_'); + +static const sal_Int16 nbOfLocales = sizeof(aLibTable) / sizeof(aLibTable[0]); + +struct LocaleDataLookupTableItem +{ + LocaleDataLookupTableItem(const sal_Char *name, osl::Module* m, const sal_Char* lname) : dllName(name), module(m), localeName(lname) + { + } + const sal_Char* dllName; + osl::Module *module; + const sal_Char* localeName; + + com::sun::star::lang::Locale aLocale; + sal_Bool equals(const com::sun::star::lang::Locale& rLocale) + { + return (rLocale == aLocale); + } +}; + +LocaleData::LocaleData() +{ +} +LocaleData::~LocaleData() +{ +} + + +LocaleDataItem SAL_CALL +LocaleData::getLocaleItem( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 dataItemCount = 0; + sal_Unicode **dataItem = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getLocaleItem" ); + + if ( func ) { + dataItem = func(dataItemCount); + + LocaleDataItem item( + dataItem[0], + dataItem[1], + dataItem[2], + dataItem[3], + dataItem[4], + dataItem[5], + dataItem[6], + dataItem[7], + dataItem[8], + dataItem[9], + dataItem[10], + dataItem[11], + dataItem[12], + dataItem[13], + dataItem[14], + dataItem[15], + dataItem[16], + dataItem[17] + ); + return item; + } + else { + LocaleDataItem item1; + return item1; + } +} + +extern "C" { static void SAL_CALL thisModule() {} } + +namespace +{ + +// implement the lookup table as a safe static object +class lcl_LookupTableHelper +{ +public: + lcl_LookupTableHelper(); + ~lcl_LookupTableHelper(); + + oslGenericFunction SAL_CALL getFunctionSymbolByName( + const OUString& localeName, const sal_Char* pFunction, + LocaleDataLookupTableItem** pOutCachedItem ); + +private: + ::osl::Mutex maMutex; + ::std::vector< LocaleDataLookupTableItem* > maLookupTable; +}; + +// from instance.hxx: Helper base class for a late-initialized +// (default-constructed) static variable, implementing the double-checked +// locking pattern correctly. +// usage: lcl_LookupTableHelper & rLookupTable = lcl_LookupTableStatic::get(); +// retrieves the singleton lookup table instance +struct lcl_LookupTableStatic : public ::rtl::Static< lcl_LookupTableHelper, lcl_LookupTableStatic > +{}; + +lcl_LookupTableHelper::lcl_LookupTableHelper() +{ +} + +lcl_LookupTableHelper::~lcl_LookupTableHelper() +{ + LocaleDataLookupTableItem* pItem = 0; + + std::vector<LocaleDataLookupTableItem*>::const_iterator aEnd(maLookupTable.end()); + std::vector<LocaleDataLookupTableItem*>::iterator aIter(maLookupTable.begin()); + + for ( ; aIter != aEnd; ++aIter ) { + pItem = *aIter; + delete pItem->module; + delete pItem; + } + maLookupTable.clear(); +} + +oslGenericFunction SAL_CALL lcl_LookupTableHelper::getFunctionSymbolByName( + const OUString& localeName, const sal_Char* pFunction, + LocaleDataLookupTableItem** pOutCachedItem ) +{ + OUString aFallback; + bool bFallback = (localeName.indexOf( under) < 0); + if (bFallback) + { + Locale aLocale; + aLocale.Language = localeName; + Locale aFbLocale = MsLangId::getFallbackLocale( aLocale); + if (aFbLocale == aLocale) + bFallback = false; // may be a "language-only-locale" like Interlingua (ia) + else if (aFbLocale.Country.getLength()) { + OUStringBuffer aBuf(5); + aFallback = aBuf.append(aFbLocale.Language).append( under).append(aFbLocale.Country).makeStringAndClear(); + } + else + aFallback = aFbLocale.Language; + } + + for ( sal_Int16 i = 0; i < nbOfLocales; i++) + { + if (localeName.equalsAscii(aLibTable[i].pLocale) || + (bFallback && localeName == aFallback)) + { + LocaleDataLookupTableItem* pCurrent = 0; + OUStringBuffer aBuf(strlen(aLibTable[i].pLocale) + 1 + strlen(pFunction)); + { + ::osl::MutexGuard aGuard( maMutex ); + for (size_t l = 0; l < maLookupTable.size(); l++) + { + pCurrent = maLookupTable[l]; + if (pCurrent->dllName == aLibTable[i].pLib) + { + OSL_ASSERT( pOutCachedItem ); + if( pOutCachedItem ) + { + (*pOutCachedItem) = new LocaleDataLookupTableItem( *pCurrent ); + (*pOutCachedItem)->localeName = aLibTable[i].pLocale; + return (*pOutCachedItem)->module->getFunctionSymbol( + aBuf.appendAscii( pFunction).append( under). + appendAscii( (*pOutCachedItem)->localeName).makeStringAndClear()); + } + else + return NULL; + } + } + } + // Library not loaded, load it and add it to the list. +#ifdef SAL_DLLPREFIX + aBuf.ensureCapacity(strlen(aLibTable[i].pLib) + 6); // mostly "lib*.so" + aBuf.appendAscii( SAL_DLLPREFIX ).appendAscii(aLibTable[i].pLib).appendAscii( SAL_DLLEXTENSION ); +#else + aBuf.ensureCapacity(strlen(aLibTable[i].pLib) + 4); // mostly "*.dll" + aBuf.appendAscii(aLibTable[i].pLib).appendAscii( SAL_DLLEXTENSION ); +#endif + osl::Module *module = new osl::Module(); + if ( module->loadRelative(&thisModule, aBuf.makeStringAndClear()) ) + { + ::osl::MutexGuard aGuard( maMutex ); + LocaleDataLookupTableItem* pNewItem = 0; + maLookupTable.push_back(pNewItem = new LocaleDataLookupTableItem(aLibTable[i].pLib, module, aLibTable[i].pLocale )); + OSL_ASSERT( pOutCachedItem ); + if( pOutCachedItem ) + { + (*pOutCachedItem) = new LocaleDataLookupTableItem( *pNewItem ); + return module->getFunctionSymbol( + aBuf.appendAscii(pFunction).append(under). + appendAscii((*pOutCachedItem)->localeName).makeStringAndClear()); + } + else + return NULL; + } + else + delete module; + } + } + return NULL; +} + +} // anonymous namespace + +#define REF_DAYS 0 +#define REF_MONTHS 1 +#define REF_ERAS 2 + +Sequence< CalendarItem > &LocaleData::getCalendarItemByName(const OUString& name, + const Locale& rLocale, const Sequence< Calendar >& calendarsSeq, sal_Int16 len, sal_Int16 item) + throw(RuntimeException) +{ + if (!ref_name.equals(name)) { + sal_Int32 index = 0; + OUString language = name.getToken(0, under, index); + OUString country = name.getToken(0, under, index); + Locale loc(language, country, OUString()); + Sequence < Calendar > cals; + if (loc == rLocale) { + cals = calendarsSeq; + } else { + cals = getAllCalendars(loc); + len = sal::static_int_cast<sal_Int16>( cals.getLength() ); + } + const OUString& id = name.getToken(0, under, index); + for (index = 0; index < cals.getLength(); index++) { + if (id.equals(cals[index].Name)) { + ref_cal = cals[index]; + break; + } + } + // Refered locale does not found, return name for en_US locale. + if (index == cals.getLength()) { + cals = getAllCalendars( + Locale(OUString::createFromAscii("en"), OUString::createFromAscii("US"), OUString())); + if (cals.getLength() > 0) + ref_cal = cals[0]; + else + throw RuntimeException(); + } + ref_name = name; + } + return item == REF_DAYS ? ref_cal.Days : item == REF_MONTHS ? ref_cal.Months : ref_cal.Eras; +} + + +Sequence< Calendar > SAL_CALL +LocaleData::getAllCalendars( const Locale& rLocale ) throw(RuntimeException) +{ + + sal_Int16 calendarsCount = 0; + sal_Unicode **allCalendars = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getAllCalendars" ); + + if ( func ) { + allCalendars = func(calendarsCount); + + Sequence< Calendar > calendarsSeq(calendarsCount); + sal_Int16 offset = 3; + sal_Int16 i, j; + for(i = 0; i < calendarsCount; i++) { + Sequence< CalendarItem > days(allCalendars[0][i]); + Sequence< CalendarItem > months(allCalendars[1][i]); + Sequence< CalendarItem > eras(allCalendars[2][i]); + OUString calendarID(allCalendars[offset]); + offset++; + sal_Bool defaultCalendar = sal::static_int_cast<sal_Bool>( allCalendars[offset][0] ); + offset++; + if (OUString(allCalendars[offset]).equalsAscii("ref")) { + days = getCalendarItemByName(OUString(allCalendars[offset+1]), rLocale, calendarsSeq, i, REF_DAYS); + offset += 2; + } else { + for(j = 0; j < allCalendars[0][i]; j++) { + CalendarItem day(allCalendars[offset], + allCalendars[offset+1], allCalendars[offset+2]); + days[j] = day; + offset += 3; + } + } + if (OUString(allCalendars[offset]).equalsAscii("ref")) { + months = getCalendarItemByName(OUString(allCalendars[offset+1]), rLocale, calendarsSeq, i, REF_MONTHS); + offset += 2; + } else { + for(j = 0; j < allCalendars[1][i]; j++) { + CalendarItem month(allCalendars[offset], + allCalendars[offset+1], allCalendars[offset+2]); + months[j] = month; + offset += 3; + } + } + if (OUString(allCalendars[offset]).equalsAscii("ref")) { + eras = getCalendarItemByName(OUString(allCalendars[offset+1]), rLocale, calendarsSeq, i, REF_ERAS); + offset += 2; + } else { + for(j = 0; j < allCalendars[2][i]; j++) { + CalendarItem era(allCalendars[offset], + allCalendars[offset+1], allCalendars[offset+2]); + eras[j] = era; + offset += 3; + } + } + OUString startOfWeekDay(allCalendars[offset]); + offset++; + sal_Int16 minimalDaysInFirstWeek = allCalendars[offset][0]; + offset++; + Calendar aCalendar(days, months, eras, startOfWeekDay, + minimalDaysInFirstWeek, defaultCalendar, calendarID); + calendarsSeq[i] = aCalendar; + } + return calendarsSeq; + } + else { + Sequence< Calendar > seq1(0); + return seq1; + } +} + + +Sequence< Currency2 > SAL_CALL +LocaleData::getAllCurrencies2( const Locale& rLocale ) throw(RuntimeException) +{ + + sal_Int16 currencyCount = 0; + sal_Unicode **allCurrencies = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getAllCurrencies" ); + + if ( func ) { + allCurrencies = func(currencyCount); + + Sequence< Currency2 > seq(currencyCount); + for(int i = 0, nOff = 0; i < currencyCount; i++, nOff += 8 ) { + Currency2 cur( + allCurrencies[nOff], // string ID + allCurrencies[nOff+1], // string Symbol + allCurrencies[nOff+2], // string BankSymbol + allCurrencies[nOff+3], // string Name + allCurrencies[nOff+4][0] != 0, // boolean Default + allCurrencies[nOff+5][0] != 0, // boolean UsedInCompatibleFormatCodes + allCurrencies[nOff+6][0], // short DecimalPlaces + allCurrencies[nOff+7][0] != 0 // boolean LegacyOnly + ); + seq[i] = cur; + } + return seq; + } + else { + Sequence< Currency2 > seq1(0); + return seq1; + } +} + + +Sequence< Currency > SAL_CALL +LocaleData::getAllCurrencies( const Locale& rLocale ) throw(RuntimeException) +{ + Sequence< Currency2 > aCur2( getAllCurrencies2( rLocale)); + sal_Int32 nLen = aCur2.getLength(); + Sequence< Currency > aCur1( nLen); + const Currency2* p2 = aCur2.getArray(); + Currency* p1 = aCur1.getArray(); + for (sal_Int32 i=0; i < nLen; ++i, ++p1, ++p2) + { + *p1 = *p2; + } + return aCur1; +} + + +// return a static (!) string resulting from replacing all occurrences of +// 'oldStr' string in 'formatCode' string with 'newStr' string +static const sal_Unicode * replace( sal_Unicode const * const formatCode, sal_Unicode const * const oldStr, sal_Unicode const * const newStr) +{ +// make reasonable assumption of maximum length of formatCode. +#define MAX_FORMATCODE_LENTH 512 + static sal_Unicode str[MAX_FORMATCODE_LENTH]; + + if (oldStr[0] == 0) // no replacement requires + return formatCode; + + sal_Int32 i = 0, k = 0; + while (formatCode[i] > 0 && k < MAX_FORMATCODE_LENTH) { + sal_Int32 j = 0, last = k; + // search oldStr in formatCode + while (formatCode[i] > 0 && oldStr[j] > 0 && k < MAX_FORMATCODE_LENTH) { + str[k++] = formatCode[i]; + if (formatCode[i++] != oldStr[j++]) + break; + } + if (oldStr[j] == 0) { + // matched string found, do replacement + k = last; j = 0; + while (newStr[j] > 0 && k < MAX_FORMATCODE_LENTH) + str[k++] = newStr[j++]; + } + } + if (k >= MAX_FORMATCODE_LENTH) // could not complete replacement, return original formatCode + return formatCode; + + str[k] = 0; + return str; +} + +Sequence< FormatElement > SAL_CALL +LocaleData::getAllFormats( const Locale& rLocale ) throw(RuntimeException) +{ + const int SECTIONS = 2; + struct FormatSection + { + MyFunc_FormatCode func; + sal_Unicode const *from; + sal_Unicode const *to; + sal_Unicode const *const *formatArray; + sal_Int16 formatCount; + + FormatSection() : func(0), from(0), to(0), formatArray(0), formatCount(0) {} + sal_Int16 getFunc( LocaleData& rLocaleData, const Locale& rL, const char* pName ) + { + func = reinterpret_cast<MyFunc_FormatCode>( rLocaleData.getFunctionSymbol( rL, pName)); + if (func) + formatArray = func( formatCount, from, to); + return formatCount; + } + } section[SECTIONS]; + +#if 0 +// #i79398# wntmsci10 MSVC doesn't get this right with optimization. + const sal_Int32 formatCount = section[0].getFunc( *this, rLocale, "getAllFormats0") + + section[1].getFunc( *this, rLocale, "getAllFormats1"); +#else + sal_Int32 formatCount = section[0].getFunc( *this, rLocale, "getAllFormats0"); + formatCount += section[1].getFunc( *this, rLocale, "getAllFormats1"); +#endif + Sequence< FormatElement > seq(formatCount); + sal_Int32 f = 0; + for (int s = 0; s < SECTIONS; ++s) + { + sal_Unicode const * const * const formatArray = section[s].formatArray; + if ( formatArray ) + { + for (int i = 0, nOff = 0; i < section[s].formatCount; ++i, nOff += 7, ++f) + { + FormatElement elem( + replace( formatArray[nOff], section[s].from, section[s].to), + formatArray[nOff + 1], + formatArray[nOff + 2], + formatArray[nOff + 3], + formatArray[nOff + 4], + formatArray[nOff + 5][0], + sal::static_int_cast<sal_Bool>(formatArray[nOff + 6][0])); + seq[f] = elem; + } + } + } + return seq; +} + +#define COLLATOR_OFFSET_ALGO 0 +#define COLLATOR_OFFSET_DEFAULT 1 +#define COLLATOR_OFFSET_RULE 2 +#define COLLATOR_ELEMENTS 3 + +OUString SAL_CALL +LocaleData::getCollatorRuleByAlgorithm( const Locale& rLocale, const OUString& algorithm ) throw(RuntimeException) +{ + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getCollatorImplementation" ); + if ( func ) { + sal_Int16 collatorCount = 0; + sal_Unicode **collatorArray = func(collatorCount); + for(sal_Int16 i = 0; i < collatorCount; i++) + if (algorithm.equals(collatorArray[i * COLLATOR_ELEMENTS + COLLATOR_OFFSET_ALGO])) + return OUString(collatorArray[i * COLLATOR_ELEMENTS + COLLATOR_OFFSET_RULE]); + } + return OUString(); +} + + +Sequence< Implementation > SAL_CALL +LocaleData::getCollatorImplementations( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 collatorCount = 0; + sal_Unicode **collatorArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getCollatorImplementation" ); + + if ( func ) { + collatorArray = func(collatorCount); + Sequence< Implementation > seq(collatorCount); + for(sal_Int16 i = 0; i < collatorCount; i++) { + Implementation impl(collatorArray[i * COLLATOR_ELEMENTS + COLLATOR_OFFSET_ALGO], + sal::static_int_cast<sal_Bool>( + collatorArray[i * COLLATOR_ELEMENTS + COLLATOR_OFFSET_DEFAULT][0])); + seq[i] = impl; + } + return seq; + } + else { + Sequence< Implementation > seq1(0); + return seq1; + } +} + +Sequence< OUString > SAL_CALL +LocaleData::getCollationOptions( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 optionsCount = 0; + sal_Unicode **optionsArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getCollationOptions" ); + + if ( func ) { + optionsArray = func(optionsCount); + Sequence< OUString > seq(optionsCount); + for(sal_Int16 i = 0; i < optionsCount; i++) { + seq[i] = OUString( optionsArray[i] ); + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } +} + +Sequence< OUString > SAL_CALL +LocaleData::getSearchOptions( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 optionsCount = 0; + sal_Unicode **optionsArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getSearchOptions" ); + + if ( func ) { + optionsArray = func(optionsCount); + Sequence< OUString > seq(optionsCount); + for(sal_Int16 i = 0; i < optionsCount; i++) { + seq[i] = OUString( optionsArray[i] ); + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } +} + +sal_Unicode ** SAL_CALL +LocaleData::getIndexArray(const Locale& rLocale, sal_Int16& indexCount) +{ + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getIndexAlgorithm" ); + + if (func) + return func(indexCount); + return NULL; +} + +Sequence< OUString > SAL_CALL +LocaleData::getIndexAlgorithm( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 indexCount = 0; + sal_Unicode **indexArray = getIndexArray(rLocale, indexCount); + + if ( indexArray ) { + Sequence< OUString > seq(indexCount); + for(sal_Int16 i = 0; i < indexCount; i++) { + seq[i] = indexArray[i*5]; + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } +} + +OUString SAL_CALL +LocaleData::getDefaultIndexAlgorithm( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 indexCount = 0; + sal_Unicode **indexArray = getIndexArray(rLocale, indexCount); + + if ( indexArray ) { + for(sal_Int16 i = 0; i < indexCount; i++) { + if (indexArray[i*5 + 3][0]) + return OUString(indexArray[i*5]); + } + } + return OUString(); +} + +sal_Bool SAL_CALL +LocaleData::hasPhonetic( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 indexCount = 0; + sal_Unicode **indexArray = getIndexArray(rLocale, indexCount); + + if ( indexArray ) { + for(sal_Int16 i = 0; i < indexCount; i++) { + if (indexArray[i*5 + 4][0]) + return sal_True; + } + } + return sal_False; +} + +sal_Unicode ** SAL_CALL +LocaleData::getIndexArrayForAlgorithm(const Locale& rLocale, const OUString& algorithm) +{ + sal_Int16 indexCount = 0; + sal_Unicode **indexArray = getIndexArray(rLocale, indexCount); + if ( indexArray ) { + for(sal_Int16 i = 0; i < indexCount; i++) { + if (algorithm.equals(indexArray[i*5])) + return indexArray+i*5; + } + } + return NULL; +} + +sal_Bool SAL_CALL +LocaleData::isPhonetic( const Locale& rLocale, const OUString& algorithm ) throw(RuntimeException) +{ + sal_Unicode **indexArray = getIndexArrayForAlgorithm(rLocale, algorithm); + return (indexArray && indexArray[4][0]) ? sal_True : sal_False; +} + +OUString SAL_CALL +LocaleData::getIndexKeysByAlgorithm( const Locale& rLocale, const OUString& algorithm ) throw(RuntimeException) +{ + sal_Unicode **indexArray = getIndexArrayForAlgorithm(rLocale, algorithm); + return indexArray ? OUString::createFromAscii("0-9")+OUString(indexArray[2]) : OUString(); +} + +OUString SAL_CALL +LocaleData::getIndexModuleByAlgorithm( const Locale& rLocale, const OUString& algorithm ) throw(RuntimeException) +{ + sal_Unicode **indexArray = getIndexArrayForAlgorithm(rLocale, algorithm); + return indexArray ? OUString(indexArray[1]) : OUString(); +} + +Sequence< UnicodeScript > SAL_CALL +LocaleData::getUnicodeScripts( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 scriptCount = 0; + sal_Unicode **scriptArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getUnicodeScripts" ); + + if ( func ) { + scriptArray = func(scriptCount); + Sequence< UnicodeScript > seq(scriptCount); + for(sal_Int16 i = 0; i < scriptCount; i++) { + seq[i] = UnicodeScript( OUString(scriptArray[i]).toInt32() ); + } + return seq; + } + else { + Sequence< UnicodeScript > seq1(0); + return seq1; + } +} + +Sequence< OUString > SAL_CALL +LocaleData::getFollowPageWords( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 wordCount = 0; + sal_Unicode **wordArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getFollowPageWords" ); + + if ( func ) { + wordArray = func(wordCount); + Sequence< OUString > seq(wordCount); + for(sal_Int16 i = 0; i < wordCount; i++) { + seq[i] = OUString(wordArray[i]); + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } +} + +Sequence< OUString > SAL_CALL +LocaleData::getTransliterations( const Locale& rLocale ) throw(RuntimeException) +{ + + sal_Int16 transliterationsCount = 0; + sal_Unicode **transliterationsArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getTransliterations" ); + + if ( func ) { + transliterationsArray = func(transliterationsCount); + + Sequence< OUString > seq(transliterationsCount); + for(int i = 0; i < transliterationsCount; i++) { + OUString elem(transliterationsArray[i]); + seq[i] = elem; + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } + + +} + + +LanguageCountryInfo SAL_CALL +LocaleData::getLanguageCountryInfo( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 LCInfoCount = 0; + sal_Unicode **LCInfoArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getLCInfo" ); + + if ( func ) { + LCInfoArray = func(LCInfoCount); + LanguageCountryInfo info(LCInfoArray[0], + LCInfoArray[1], + LCInfoArray[2], + LCInfoArray[3], + LCInfoArray[4]); + return info; + } + else { + LanguageCountryInfo info1; + return info1; + } + +} + + +ForbiddenCharacters SAL_CALL +LocaleData::getForbiddenCharacters( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 LCForbiddenCharactersCount = 0; + sal_Unicode **LCForbiddenCharactersArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getForbiddenCharacters" ); + + if ( func ) { + LCForbiddenCharactersArray = func(LCForbiddenCharactersCount); + ForbiddenCharacters chars(LCForbiddenCharactersArray[0], LCForbiddenCharactersArray[1]); + return chars; + } + else { + ForbiddenCharacters chars1; + return chars1; + } +} + +OUString SAL_CALL +LocaleData::getHangingCharacters( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 LCForbiddenCharactersCount = 0; + sal_Unicode **LCForbiddenCharactersArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getForbiddenCharacters" ); + + if ( func ) { + LCForbiddenCharactersArray = func(LCForbiddenCharactersCount); + return OUString(LCForbiddenCharactersArray[2]); + } + + return OUString(); +} + +Sequence< OUString > SAL_CALL +LocaleData::getBreakIteratorRules( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 LCBreakIteratorRuleCount = 0; + sal_Unicode **LCBreakIteratorRulesArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getBreakIteratorRules" ); + + if ( func ) { + LCBreakIteratorRulesArray = func(LCBreakIteratorRuleCount); + Sequence< OUString > seq(LCBreakIteratorRuleCount); + for(int i = 0; i < (LCBreakIteratorRuleCount); i++) { + OUString elem(LCBreakIteratorRulesArray[i]); + seq[i] = elem; + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } +} + + +Sequence< OUString > SAL_CALL +LocaleData::getReservedWord( const Locale& rLocale ) throw(RuntimeException) +{ + sal_Int16 LCReservedWordsCount = 0; + sal_Unicode **LCReservedWordsArray = NULL; + + MyFunc_Type func = (MyFunc_Type) getFunctionSymbol( rLocale, "getReservedWords" ); + + if ( func ) { + LCReservedWordsArray = func(LCReservedWordsCount); + Sequence< OUString > seq(LCReservedWordsCount); + for(int i = 0; i < (LCReservedWordsCount); i++) { + OUString elem(LCReservedWordsArray[i]); + seq[i] = elem; + } + return seq; + } + else { + Sequence< OUString > seq1(0); + return seq1; + } +} + + +inline +OUString C2U( const char* s ) +{ + return OUString::createFromAscii( s ); +} + +Sequence< Sequence<beans::PropertyValue> > SAL_CALL +LocaleData::getContinuousNumberingLevels( const lang::Locale& rLocale ) throw(RuntimeException) +{ + int i; + + // load symbol + MyFunc_Type2 func = (MyFunc_Type2) getFunctionSymbol( rLocale, "getContinuousNumberingLevels" ); + + if ( func ) + { + // invoke function + sal_Int16 nStyles; + sal_Int16 nAttributes; + sal_Unicode*** p0 = func( nStyles, nAttributes ); + + // allocate memory for nAttributes attributes for each of the nStyles styles. + Sequence< Sequence<beans::PropertyValue> > pv( nStyles ); + for( i=0; i<pv.getLength(); i++ ) { + pv[i] = Sequence<beans::PropertyValue>( nAttributes ); + } + + sal_Unicode*** pStyle = p0; + for( i=0; i<nStyles; i++ ) { + sal_Unicode** pAttribute = pStyle[i]; + for( int j=0; j<nAttributes; j++ ) { // prefix, numberingtype, ... + sal_Unicode* pString = pAttribute[j]; + beans::PropertyValue& rVal = pv[i][j]; + OUString sVal; + if( pString ) { + if( 0 != j && 2 != j ) + sVal = pString; + else if( *pString ) + sVal = OUString( pString, 1 ); + } + + switch( j ) + { + case 0: + rVal.Name = C2U("Prefix"); + rVal.Value <<= sVal; + break; + case 1: + rVal.Name = C2U("NumberingType"); + rVal.Value <<= (sal_Int16) sVal.toInt32(); + break; + case 2: + rVal.Name = C2U("Suffix"); + rVal.Value <<= sVal; + break; + case 3: + rVal.Name = C2U("Transliteration"); + rVal.Value <<= sVal; + break; + case 4: + rVal.Name = C2U("NatNum"); + rVal.Value <<= (sal_Int16) sVal.toInt32(); + break; + default: + OSL_ASSERT(0); + } + } + } + return pv; + } + + Sequence< Sequence<beans::PropertyValue> > seq1(0); + return seq1; +} + +// ============================================================================ +// \/ OutlineNumbering helper class \/ +// +#include <com/sun/star/container/XIndexAccess.hpp> +#include <cppuhelper/implbase1.hxx> + +namespace com{ namespace sun{ namespace star{ namespace lang { + struct Locale; +}}}} +//----------------------------------------------------------------------------- +struct OutlineNumberingLevel_Impl +{ + OUString sPrefix; + sal_Int16 nNumType; //com::sun::star::style::NumberingType + OUString sSuffix; + sal_Unicode cBulletChar; + const sal_Char* sBulletFontName; + sal_Int16 nParentNumbering; + sal_Int32 nLeftMargin; + sal_Int32 nSymbolTextDistance; + sal_Int32 nFirstLineOffset; + OUString sTransliteration; + sal_Int32 nNatNum; +}; +//----------------------------------------------------------------------------- +class OutlineNumbering : public cppu::WeakImplHelper1 < container::XIndexAccess > +{ + const OutlineNumberingLevel_Impl* m_pOutlineLevels; + sal_Int16 m_nCount; +public: +// OutlineNumbering(const OutlineNumberingLevel_Impl* pOutlineLevels); + OutlineNumbering(const OutlineNumberingLevel_Impl* pOutlineLevels, int nLevels); + ~OutlineNumbering(); + + //XIndexAccess + virtual sal_Int32 SAL_CALL getCount( ) throw(RuntimeException); + virtual Any SAL_CALL getByIndex( sal_Int32 Index ) + throw(IndexOutOfBoundsException, WrappedTargetException, RuntimeException); + + //XElementAccess + virtual Type SAL_CALL getElementType( ) throw(RuntimeException); + virtual sal_Bool SAL_CALL hasElements( ) throw(RuntimeException); +}; + +// +// OutlineNumbering helper class +// ============================================================================ + +static +sal_Char* U2C( OUString str ) +{ + sal_Char* s = new sal_Char[ str.getLength()+1 ]; + int i; + for( i = 0; i < str.getLength(); i++) + s[i] = sal::static_int_cast<sal_Char>( str[i] ); + s[i]='\0'; + return s; +} + + +Sequence< Reference<container::XIndexAccess> > SAL_CALL +LocaleData::getOutlineNumberingLevels( const lang::Locale& rLocale ) throw(RuntimeException) +{ + int i; + + // load symbol + MyFunc_Type3 func = (MyFunc_Type3) getFunctionSymbol( rLocale, "getOutlineNumberingLevels" ); + + if ( func ) + { + // invoke function + sal_Int16 nStyles; + sal_Int16 nLevels; + sal_Int16 nAttributes; + sal_Unicode**** p0 = func( nStyles, nLevels, nAttributes ); + + Sequence< Reference<container::XIndexAccess> > aRet( nStyles ); + + OUString aEmptyStr; + + sal_Unicode**** pStyle = p0; + for( i=0; i<nStyles; i++ ) + { + int j; + + OutlineNumberingLevel_Impl* level = new OutlineNumberingLevel_Impl[ nLevels+1 ]; + sal_Unicode*** pLevel = pStyle[i]; + for( j = 0; j < nLevels; j++ ) + { + sal_Unicode** pAttribute = pLevel[j]; + for( int k=0; k<nAttributes; k++ ) + { + OUString tmp( pAttribute[k] ); + switch( k ) + { + case 0: level[j].sPrefix = tmp; break; + case 1: level[j].nNumType = sal::static_int_cast<sal_Int16>(tmp.toInt32()); break; + case 2: level[j].sSuffix = tmp; break; + //case 3: level[j].cBulletChar = tmp.toChar(); break; + case 3: level[j].cBulletChar = sal::static_int_cast<sal_Unicode>(tmp.toInt32(16)); break; // base 16 + case 4: level[j].sBulletFontName = U2C( tmp ); break; + case 5: level[j].nParentNumbering = sal::static_int_cast<sal_Int16>(tmp.toInt32()); break; + case 6: level[j].nLeftMargin = tmp.toInt32(); break; + case 7: level[j].nSymbolTextDistance = tmp.toInt32(); break; + case 8: level[j].nFirstLineOffset = tmp.toInt32(); break; + case 9: // Adjust + // these values seem to be hard-coded elsewhere: + // level[j].Value <<= (sal_Int16) text::HoriOrientation::LEFT; + // level[j].Value <<= (sal_Int16) style::HorizontalAlignment::LEFT; + break; + case 10: level[j].sTransliteration = tmp; break; + case 11: level[j].nNatNum = tmp.toInt32(); break; + default: + OSL_ASSERT(0); + } + } + } + level[j].sPrefix = aEmptyStr; + level[j].nNumType = 0; + level[j].sSuffix = aEmptyStr; + level[j].cBulletChar = 0; + level[j].sBulletFontName = 0; + level[j].nParentNumbering = 0; + level[j].nLeftMargin = 0; + level[j].nSymbolTextDistance = 0; + level[j].nFirstLineOffset = 0; + level[j].sTransliteration = aEmptyStr; + level[j].nNatNum = 0; + aRet[i] = new OutlineNumbering( level, nLevels ); + } + return aRet; + } + else { + Sequence< Reference<container::XIndexAccess> > seq1(0); + return seq1; + } +} + +///////////////////////////////////////////////////////////////////////////////////////////// +//////////////////////////////////helper functions/////////////////////////////////////////// +///////////////////////////////////////////////////////////////////////////////////////////// + +oslGenericFunction SAL_CALL LocaleData::getFunctionSymbol( const Locale& rLocale, const sal_Char* pFunction ) + throw(RuntimeException) +{ + lcl_LookupTableHelper & rLookupTable = lcl_LookupTableStatic::get(); + + OUStringBuffer aBuf(1); + if (cachedItem.get() && cachedItem->equals(rLocale)) { + aBuf.ensureCapacity(strlen(pFunction) + 1 + strlen(cachedItem->localeName)); + return cachedItem->module->getFunctionSymbol(aBuf.appendAscii(pFunction).append(under). + appendAscii(cachedItem->localeName).makeStringAndClear()); + } + + oslGenericFunction pSymbol = 0; + static OUString tw(OUString::createFromAscii("TW")); + static OUString en_US(OUString::createFromAscii("en_US")); + + sal_Int32 l = rLocale.Language.getLength(); + sal_Int32 c = rLocale.Country.getLength(); + sal_Int32 v = rLocale.Variant.getLength(); + aBuf.ensureCapacity(l+c+v+3); + + LocaleDataLookupTableItem *pCachedItem = 0; + + if ((l > 0 && c > 0 && v > 0 && + // load function with name <func>_<lang>_<country>_<varian> + (pSymbol = rLookupTable.getFunctionSymbolByName(aBuf.append(rLocale.Language).append(under).append( + rLocale.Country).append(under).append(rLocale.Variant).makeStringAndClear(), pFunction, &pCachedItem)) != 0) || + (l > 0 && c > 0 && + // load function with name <ase>_<lang>_<country> + (pSymbol = rLookupTable.getFunctionSymbolByName(aBuf.append(rLocale.Language).append(under).append( + rLocale.Country).makeStringAndClear(), pFunction, &pCachedItem)) != 0) || + (l > 0 && c > 0 && rLocale.Language.equalsAscii("zh") && + (rLocale.Country.equalsAscii("HK") || + rLocale.Country.equalsAscii("MO")) && + // if the country code is HK or MO, one more step to try TW. + (pSymbol = rLookupTable.getFunctionSymbolByName(aBuf.append(rLocale.Language).append(under).append(tw).makeStringAndClear(), + pFunction, &pCachedItem)) != 0) || + (l > 0 && + // load function with name <func>_<lang> + (pSymbol = rLookupTable.getFunctionSymbolByName(rLocale.Language, pFunction, &pCachedItem)) != 0) || + // load default function with name <func>_en_US + (pSymbol = rLookupTable.getFunctionSymbolByName(en_US, pFunction, &pCachedItem)) != 0) + { + if( pCachedItem ) + cachedItem.reset( pCachedItem ); + if( cachedItem.get()) + cachedItem->aLocale = rLocale; + return pSymbol; + } + throw RuntimeException(); +} + +Sequence< Locale > SAL_CALL +LocaleData::getAllInstalledLocaleNames() throw(RuntimeException) +{ + Sequence< lang::Locale > seq( nbOfLocales ); + OUString empStr; + sal_Int16 nInstalled = 0; + + for( sal_Int16 i=0; i<nbOfLocales; i++ ) { + OUString name = OUString::createFromAscii( aLibTable[i].pLocale ); + + // Check if the locale is really available and not just in the table, + // don't allow fall backs. + LocaleDataLookupTableItem *pCachedItem = 0; + if (lcl_LookupTableStatic::get().getFunctionSymbolByName( name, "getLocaleItem", &pCachedItem )) { + if( pCachedItem ) + cachedItem.reset( pCachedItem ); + sal_Int32 index = 0; + lang::Locale tmpLocale(name.getToken(0, under, index), empStr, empStr); + if (index >= 0) { + tmpLocale.Country = name.getToken(0, under, index); + if (index >= 0) + tmpLocale.Variant = name.getToken(0, under, index); + } + seq[nInstalled++] = tmpLocale; + } + } + if ( nInstalled < nbOfLocales ) + seq.realloc( nInstalled ); // reflect reality + + return seq; +} + +// ============================================================================ + +using namespace ::com::sun::star::container; +using namespace ::com::sun::star::beans; +using namespace ::com::sun::star::style; +using namespace ::com::sun::star::text; + +// // bad: can't have empty prefix ... +// OutlineNumbering::OutlineNumbering(const OutlineNumberingLevel_Impl* pOutlnLevels) : +// m_pOutlineLevels(pOutlnLevels), +// m_nCount(0) +// { +// const OutlineNumberingLevel_Impl* pTemp = m_pOutlineLevels; +// while((pTemp++)->sPrefix) +// m_nCount++; +// } + +OutlineNumbering::OutlineNumbering(const OutlineNumberingLevel_Impl* pOutlnLevels, int nLevels) : + m_pOutlineLevels(pOutlnLevels), + m_nCount(sal::static_int_cast<sal_Int16>(nLevels)) +{ +} + +OutlineNumbering::~OutlineNumbering() +{ + delete [] m_pOutlineLevels; +} + +sal_Int32 OutlineNumbering::getCount( ) throw(RuntimeException) +{ + return m_nCount; +} + +Any OutlineNumbering::getByIndex( sal_Int32 nIndex ) + throw(IndexOutOfBoundsException, WrappedTargetException, RuntimeException) +{ + if(nIndex < 0 || nIndex >= m_nCount) + throw IndexOutOfBoundsException(); + const OutlineNumberingLevel_Impl* pTemp = m_pOutlineLevels; + pTemp += nIndex; + Any aRet; + + Sequence<PropertyValue> aOutlineNumbering(12); + PropertyValue* pValues = aOutlineNumbering.getArray(); + pValues[0].Name = C2U( "Prefix"); + pValues[0].Value <<= pTemp->sPrefix; + pValues[1].Name = C2U("NumberingType"); + pValues[1].Value <<= pTemp->nNumType; + pValues[2].Name = C2U("Suffix"); + pValues[2].Value <<= pTemp->sSuffix; + pValues[3].Name = C2U("BulletChar"); + pValues[3].Value <<= OUString(&pTemp->cBulletChar, 1); + pValues[4].Name = C2U("BulletFontName"); + pValues[4].Value <<= C2U(pTemp->sBulletFontName); + pValues[5].Name = C2U("ParentNumbering"); + pValues[5].Value <<= pTemp->nParentNumbering; + pValues[6].Name = C2U("LeftMargin"); + pValues[6].Value <<= pTemp->nLeftMargin; + pValues[7].Name = C2U("SymbolTextDistance"); + pValues[7].Value <<= pTemp->nSymbolTextDistance; + pValues[8].Name = C2U("FirstLineOffset"); + pValues[8].Value <<= pTemp->nFirstLineOffset; + pValues[9].Name = C2U("Adjust"); + pValues[9].Value <<= (sal_Int16)HoriOrientation::LEFT; + pValues[10].Name = C2U("Transliteration"); + pValues[10].Value <<= pTemp->sTransliteration; + pValues[11].Name = C2U("NatNum"); + pValues[11].Value <<= pTemp->nNatNum; + aRet <<= aOutlineNumbering; + return aRet; +} + +Type OutlineNumbering::getElementType( ) throw(RuntimeException) +{ + return ::getCppuType((Sequence<PropertyValue>*)0); +} + +sal_Bool OutlineNumbering::hasElements( ) throw(RuntimeException) +{ + return m_nCount > 0; +} + +OUString SAL_CALL +LocaleData::getImplementationName() throw( RuntimeException ) +{ + return OUString::createFromAscii(clocaledata); +} + +sal_Bool SAL_CALL +LocaleData::supportsService(const OUString& rServiceName) + throw( RuntimeException ) +{ + return !rServiceName.compareToAscii(clocaledata); +} + +Sequence< OUString > SAL_CALL +LocaleData::getSupportedServiceNames() throw( RuntimeException ) +{ + Sequence< OUString > aRet(1); + aRet[0] = OUString::createFromAscii(clocaledata); + return aRet; +} |