diff options
Diffstat (limited to 'i18npool/source/indexentry/indexentrysupplier.cxx')
-rw-r--r-- | i18npool/source/indexentry/indexentrysupplier.cxx | 209 |
1 files changed, 209 insertions, 0 deletions
diff --git a/i18npool/source/indexentry/indexentrysupplier.cxx b/i18npool/source/indexentry/indexentrysupplier.cxx new file mode 100644 index 000000000000..3321559e478f --- /dev/null +++ b/i18npool/source/indexentry/indexentrysupplier.cxx @@ -0,0 +1,209 @@ +/************************************************************************* + * + * 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 <rtl/ustrbuf.hxx> +#include <indexentrysupplier.hxx> +#include <localedata.hxx> + +using namespace ::com::sun::star::uno; +using namespace ::com::sun::star::lang; +using namespace ::rtl; + +static const sal_Unicode under = sal_Unicode('_'); + +namespace com { namespace sun { namespace star { namespace i18n { + +IndexEntrySupplier::IndexEntrySupplier( const Reference < XMultiServiceFactory >& rxMSF ) : xMSF( rxMSF ) +{ +} + +Sequence < Locale > SAL_CALL IndexEntrySupplier::getLocaleList() throw (RuntimeException) +{ + return LocaleData().getAllInstalledLocaleNames(); +} + +Sequence < OUString > SAL_CALL IndexEntrySupplier::getAlgorithmList( const Locale& rLocale ) throw (RuntimeException) +{ + return LocaleData().getIndexAlgorithm(rLocale); +} + +sal_Bool SAL_CALL IndexEntrySupplier::loadAlgorithm( const Locale& rLocale, const OUString& SortAlgorithm, + sal_Int32 collatorOptions ) throw (RuntimeException) +{ + Sequence < OUString > algorithmList = getAlgorithmList( rLocale ); + for (sal_Int32 i = 0; i < algorithmList.getLength(); i++) { + if (algorithmList[i] == SortAlgorithm) { + if (getLocaleSpecificIndexEntrySupplier(rLocale, SortAlgorithm).is()) + return xIES->loadAlgorithm(rLocale, SortAlgorithm, collatorOptions); + } + } + return sal_False; +} + +sal_Bool SAL_CALL IndexEntrySupplier::usePhoneticEntry( const Locale& rLocale ) throw (RuntimeException) +{ + return LocaleData().hasPhonetic(rLocale); +} + +OUString SAL_CALL IndexEntrySupplier::getPhoneticCandidate( const OUString& rIndexEntry, + const Locale& rLocale ) throw (RuntimeException) +{ + if (getLocaleSpecificIndexEntrySupplier(rLocale, OUString()).is()) + return xIES->getPhoneticCandidate(rIndexEntry, rLocale); + else + throw RuntimeException(); +} + +OUString SAL_CALL IndexEntrySupplier::getIndexKey( const OUString& rIndexEntry, + const OUString& rPhoneticEntry, const Locale& rLocale ) throw (RuntimeException) +{ + if (xIES.is()) + return xIES->getIndexKey(rIndexEntry, rPhoneticEntry, rLocale); + else + throw RuntimeException(); +} + +sal_Int16 SAL_CALL IndexEntrySupplier::compareIndexEntry( + const OUString& rIndexEntry1, const OUString& rPhoneticEntry1, const Locale& rLocale1, + const OUString& rIndexEntry2, const OUString& rPhoneticEntry2, const Locale& rLocale2 ) + throw (com::sun::star::uno::RuntimeException) +{ + if (xIES.is()) + return xIES->compareIndexEntry(rIndexEntry1, rPhoneticEntry1, rLocale1, + rIndexEntry2, rPhoneticEntry2, rLocale2); + else + throw RuntimeException(); +} + +OUString SAL_CALL IndexEntrySupplier::getIndexCharacter( const OUString& rIndexEntry, + const Locale& rLocale, const OUString& rSortAlgorithm ) + throw (RuntimeException) +{ + return getLocaleSpecificIndexEntrySupplier(rLocale, rSortAlgorithm)-> + getIndexCharacter( rIndexEntry, rLocale, rSortAlgorithm ); +} + +sal_Bool SAL_CALL IndexEntrySupplier::createLocaleSpecificIndexEntrySupplier(const OUString& name) throw( RuntimeException ) +{ + Reference < XInterface > xI = xMSF->createInstance( + OUString::createFromAscii("com.sun.star.i18n.IndexEntrySupplier_") + name); + + if ( xI.is() ) { + xI->queryInterface( ::getCppuType((const Reference< com::sun::star::i18n::XExtendedIndexEntrySupplier>*)0) ) >>= xIES; + return xIES.is(); + } + return sal_False; +} + +Reference < com::sun::star::i18n::XExtendedIndexEntrySupplier > SAL_CALL +IndexEntrySupplier::getLocaleSpecificIndexEntrySupplier(const Locale& rLocale, const OUString& rSortAlgorithm) throw (RuntimeException) +{ + if (xIES.is() && rSortAlgorithm == aSortAlgorithm && rLocale.Language == aLocale.Language && + rLocale.Country == aLocale.Country && rLocale.Variant == aLocale.Variant) + return xIES; + else if (xMSF.is()) { + LocaleData ld; + aLocale = rLocale; + if (rSortAlgorithm.getLength() == 0) + aSortAlgorithm = ld.getDefaultIndexAlgorithm( rLocale ); + else + aSortAlgorithm = rSortAlgorithm; + + OUString module = ld.getIndexModuleByAlgorithm(rLocale, aSortAlgorithm); + if (module.getLength() > 0 && createLocaleSpecificIndexEntrySupplier(module)) + return xIES; + + sal_Int32 l = rLocale.Language.getLength(); + sal_Int32 c = rLocale.Country.getLength(); + sal_Int32 v = rLocale.Variant.getLength(); + sal_Int32 a = aSortAlgorithm.getLength(); + OUStringBuffer aBuf(l+c+v+a+4); + + if ((l > 0 && c > 0 && v > 0 && a > 0 && + // load service with name <base>_<lang>_<country>_<varian>_<algorithm> + createLocaleSpecificIndexEntrySupplier(aBuf.append(rLocale.Language).append(under).append( + rLocale.Country).append(under).append(rLocale.Variant).append(under).append( + aSortAlgorithm).makeStringAndClear())) || + (l > 0 && c > 0 && a > 0 && + // load service with name <base>_<lang>_<country>_<algorithm> + createLocaleSpecificIndexEntrySupplier(aBuf.append(rLocale.Language).append(under).append( + rLocale.Country).append(under).append(aSortAlgorithm).makeStringAndClear())) || + (l > 0 && c > 0 && a > 0 && rLocale.Language.compareToAscii("zh") == 0 && + (rLocale.Country.compareToAscii("HK") == 0 || + rLocale.Country.compareToAscii("MO") == 0) && + // if the country code is HK or MO, one more step to try TW. + createLocaleSpecificIndexEntrySupplier(aBuf.append(rLocale.Language).append(under).appendAscii( + "TW").append(under).append(aSortAlgorithm).makeStringAndClear())) || + (l > 0 && a > 0 && + // load service with name <base>_<lang>_<algorithm> + createLocaleSpecificIndexEntrySupplier(aBuf.append(rLocale.Language).append(under).append( + aSortAlgorithm).makeStringAndClear())) || + // load service with name <base>_<algorithm> + (a > 0 && createLocaleSpecificIndexEntrySupplier(aSortAlgorithm)) || + // load default service with name <base>_Unicode + createLocaleSpecificIndexEntrySupplier(OUString::createFromAscii("Unicode"))) { + return xIES; + } + } + throw RuntimeException(); +} + +OUString SAL_CALL IndexEntrySupplier::getIndexFollowPageWord( sal_Bool bMorePages, + const Locale& rLocale ) throw (RuntimeException) +{ + Sequence< OUString > aFollowPageWords = LocaleData().getFollowPageWords(rLocale); + + return (bMorePages && aFollowPageWords.getLength() > 1) ? + aFollowPageWords[1] : (aFollowPageWords.getLength() > 0 ? + aFollowPageWords[0] : OUString()); +} + +#define implementationName "com.sun.star.i18n.IndexEntrySupplier" + +OUString SAL_CALL +IndexEntrySupplier::getImplementationName() throw( RuntimeException ) +{ + return OUString::createFromAscii( implementationName ); +} + +sal_Bool SAL_CALL +IndexEntrySupplier::supportsService(const OUString& rServiceName) throw( RuntimeException ) +{ + return rServiceName.compareToAscii(implementationName) == 0; +} + +Sequence< OUString > SAL_CALL +IndexEntrySupplier::getSupportedServiceNames() throw( RuntimeException ) +{ + Sequence< OUString > aRet(1); + aRet[0] = OUString::createFromAscii( implementationName ); + return aRet; +} + +} } } } |