summaryrefslogtreecommitdiff
path: root/svl/source/config/cjkoptions.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'svl/source/config/cjkoptions.cxx')
-rw-r--r--svl/source/config/cjkoptions.cxx506
1 files changed, 111 insertions, 395 deletions
diff --git a/svl/source/config/cjkoptions.cxx b/svl/source/config/cjkoptions.cxx
index 84c972875f3a..572794926a04 100644
--- a/svl/source/config/cjkoptions.cxx
+++ b/svl/source/config/cjkoptions.cxx
@@ -19,453 +19,169 @@
#include <svl/cjkoptions.hxx>
-#include <o3tl/any.hxx>
#include <svl/languageoptions.hxx>
#include <i18nlangtag/lang.h>
#include <i18nlangtag/languagetag.hxx>
#include <unotools/configitem.hxx>
#include <com/sun/star/uno/Any.h>
#include <com/sun/star/uno/Sequence.hxx>
-#include <osl/mutex.hxx>
-#include <rtl/instance.hxx>
#include <officecfg/System.hxx>
-
-#include "itemholder2.hxx"
+#include <officecfg/Office/Common.hxx>
+#include <mutex>
using namespace ::com::sun::star::uno;
-#define CFG_READONLY_DEFAULT false
+static void SvtCJKOptions_Load();
-class SvtCJKOptions_Impl : public utl::ConfigItem
+namespace SvtCJKOptions
{
- bool bIsLoaded;
- bool bCJKFont;
- bool bVerticalText;
- bool bAsianTypography;
- bool bJapaneseFind;
- bool bRuby;
- bool bChangeCaseMap;
- bool bDoubleLines;
- bool bEmphasisMarks;
- bool bVerticalCallOut;
-
- bool bROCJKFont;
- bool bROVerticalText;
- bool bROAsianTypography;
- bool bROJapaneseFind;
- bool bRORuby;
- bool bROChangeCaseMap;
- bool bRODoubleLines;
- bool bROEmphasisMarks;
- bool bROVerticalCallOut;
-
- virtual void ImplCommit() override;
-
-public:
- SvtCJKOptions_Impl();
-
- virtual void Notify( const css::uno::Sequence< OUString >& rPropertyNames ) override;
- void Load();
-
- bool IsLoaded() const { return bIsLoaded; }
-
- bool IsCJKFontEnabled() const { return bCJKFont; }
- bool IsVerticalTextEnabled() const { return bVerticalText; }
- bool IsAsianTypographyEnabled() const { return bAsianTypography; }
- bool IsJapaneseFindEnabled() const { return bJapaneseFind; }
- bool IsRubyEnabled() const { return bRuby; }
- bool IsChangeCaseMapEnabled() const { return bChangeCaseMap; }
- bool IsDoubleLinesEnabled() const { return bDoubleLines; }
- bool IsAnyEnabled() const {
- return bCJKFont||bVerticalText||bAsianTypography||bJapaneseFind||
- bRuby||bChangeCaseMap||bDoubleLines||bEmphasisMarks||bVerticalCallOut; }
- void SetAll(bool bSet);
- bool IsReadOnly(SvtCJKOptions::EOption eOption) const;
-};
-
-namespace
+bool IsCJKFontEnabled()
{
- struct PropertyNames
- : public rtl::Static< Sequence<OUString>, PropertyNames > {};
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::CJKFont::get();
}
-SvtCJKOptions_Impl::SvtCJKOptions_Impl() :
- utl::ConfigItem("Office.Common/I18N/CJK"),
- bIsLoaded(false),
- bCJKFont(true),
- bVerticalText(true),
- bAsianTypography(true),
- bJapaneseFind(true),
- bRuby(true),
- bChangeCaseMap(true),
- bDoubleLines(true),
- bEmphasisMarks(true),
- bVerticalCallOut(true),
- bROCJKFont(CFG_READONLY_DEFAULT),
- bROVerticalText(CFG_READONLY_DEFAULT),
- bROAsianTypography(CFG_READONLY_DEFAULT),
- bROJapaneseFind(CFG_READONLY_DEFAULT),
- bRORuby(CFG_READONLY_DEFAULT),
- bROChangeCaseMap(CFG_READONLY_DEFAULT),
- bRODoubleLines(CFG_READONLY_DEFAULT),
- bROEmphasisMarks(CFG_READONLY_DEFAULT),
- bROVerticalCallOut(CFG_READONLY_DEFAULT)
+bool IsVerticalTextEnabled()
{
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::VerticalText::get();
}
-void SvtCJKOptions_Impl::SetAll(bool bSet)
+bool IsAsianTypographyEnabled()
{
- if (
- bROCJKFont ||
- bROVerticalText ||
- bROAsianTypography ||
- bROJapaneseFind ||
- bRORuby ||
- bROChangeCaseMap ||
- bRODoubleLines ||
- bROEmphasisMarks ||
- bROVerticalCallOut
- )
- return;
-
- bCJKFont=bSet;
- bVerticalText=bSet;
- bAsianTypography=bSet;
- bJapaneseFind=bSet;
- bRuby=bSet;
- bChangeCaseMap=bSet;
- bDoubleLines=bSet;
- bEmphasisMarks=bSet;
- bVerticalCallOut=bSet;
-
- SetModified();
- Commit();
- NotifyListeners(ConfigurationHints::NONE);
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::AsianTypography::get();
}
-void SvtCJKOptions_Impl::Load()
+bool IsJapaneseFindEnabled()
{
- Sequence<OUString> &rPropertyNames = PropertyNames::get();
- if(!rPropertyNames.hasElements())
- {
- rPropertyNames.realloc(9);
- OUString* pNames = rPropertyNames.getArray();
-
- pNames[0] = "CJKFont";
- pNames[1] = "VerticalText";
- pNames[2] = "AsianTypography";
- pNames[3] = "JapaneseFind";
- pNames[4] = "Ruby";
- pNames[5] = "ChangeCaseMap";
- pNames[6] = "DoubleLines";
- pNames[7] = "EmphasisMarks";
- pNames[8] = "VerticalCallOut";
-
- EnableNotification( rPropertyNames );
- }
- Sequence< Any > aValues = GetProperties(rPropertyNames);
- Sequence< sal_Bool > aROStates = GetReadOnlyStates(rPropertyNames);
- const Any* pValues = aValues.getConstArray();
- const sal_Bool* pROStates = aROStates.getConstArray();
- assert(aValues.getLength() == rPropertyNames.getLength() && "GetProperties failed");
- assert(aROStates.getLength() == rPropertyNames.getLength() && "GetReadOnlyStates failed");
- if ( aValues.getLength() == rPropertyNames.getLength() && aROStates.getLength() == rPropertyNames.getLength() )
- {
- for ( int nProp = 0; nProp < rPropertyNames.getLength(); nProp++ )
- {
- if( pValues[nProp].hasValue() )
- {
- bool bValue = *o3tl::doAccess<bool>(pValues[nProp]);
- switch ( nProp )
- {
- case 0: { bCJKFont = bValue; bROCJKFont = pROStates[nProp]; } break;
- case 1: { bVerticalText = bValue; bROVerticalText = pROStates[nProp]; } break;
- case 2: { bAsianTypography = bValue; bROAsianTypography = pROStates[nProp]; } break;
- case 3: { bJapaneseFind = bValue; bROJapaneseFind = pROStates[nProp]; } break;
- case 4: { bRuby = bValue; bRORuby = pROStates[nProp]; } break;
- case 5: { bChangeCaseMap = bValue; bROChangeCaseMap = pROStates[nProp]; } break;
- case 6: { bDoubleLines = bValue; bRODoubleLines = pROStates[nProp]; } break;
- case 7: { bEmphasisMarks = bValue; bROEmphasisMarks = pROStates[nProp]; } break;
- case 8: { bVerticalCallOut = bValue; bROVerticalCallOut = pROStates[nProp]; } break;
- }
- }
- }
- }
-
- if (!bCJKFont)
- {
- SvtScriptType nScriptType = SvtLanguageOptions::GetScriptTypeOfLanguage(LANGUAGE_SYSTEM);
- //system locale is CJK
- bool bAutoEnableCJK = bool(nScriptType & SvtScriptType::ASIAN);
-
- if (!bAutoEnableCJK)
- {
- //windows secondary system locale is CJK
- OUString sWin16SystemLocale = officecfg::System::L10N::SystemLocale::get();
- LanguageType eSystemLanguage = LANGUAGE_NONE;
- if( !sWin16SystemLocale.isEmpty() )
- eSystemLanguage = LanguageTag::convertToLanguageTypeWithFallback( sWin16SystemLocale );
- if (eSystemLanguage != LANGUAGE_SYSTEM)
- {
- SvtScriptType nWinScript = SvtLanguageOptions::GetScriptTypeOfLanguage( eSystemLanguage );
- bAutoEnableCJK = bool(nWinScript & SvtScriptType::ASIAN);
- }
-
- //CJK keyboard is installed
- if (!bAutoEnableCJK)
- bAutoEnableCJK = SvtSystemLanguageOptions::isCJKKeyboardLayoutInstalled();
- }
-
- if (bAutoEnableCJK)
- {
- SetAll(true);
- }
- }
- bIsLoaded = true;
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::JapaneseFind::get();
}
-void SvtCJKOptions_Impl::Notify( const Sequence< OUString >& )
+bool IsRubyEnabled()
{
- Load();
- NotifyListeners(ConfigurationHints::NONE);
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::Ruby::get();
}
-void SvtCJKOptions_Impl::ImplCommit()
+bool IsChangeCaseMapEnabled()
{
- Sequence<OUString> &rPropertyNames = PropertyNames::get();
- OUString* pOrgNames = rPropertyNames.getArray();
- sal_Int32 nOrgCount = rPropertyNames.getLength();
-
- Sequence< OUString > aNames(nOrgCount);
- Sequence< Any > aValues(nOrgCount);
-
- OUString* pNames = aNames.getArray();
- Any* pValues = aValues.getArray();
- sal_Int32 nRealCount = 0;
-
- for(int nProp = 0; nProp < nOrgCount; nProp++)
- {
- switch(nProp)
- {
- case 0:
- {
- if (!bROCJKFont)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bCJKFont;
- ++nRealCount;
- }
- }
- break;
-
- case 1:
- {
- if (!bROVerticalText)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bVerticalText;
- ++nRealCount;
- }
- }
- break;
-
- case 2:
- {
- if (!bROAsianTypography)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bAsianTypography;
- ++nRealCount;
- }
- }
- break;
-
- case 3:
- {
- if (!bROJapaneseFind)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bJapaneseFind;
- ++nRealCount;
- }
- }
- break;
-
- case 4:
- {
- if (!bRORuby)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bRuby;
- ++nRealCount;
- }
- }
- break;
-
- case 5:
- {
- if (!bROChangeCaseMap)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bChangeCaseMap;
- ++nRealCount;
- }
- }
- break;
-
- case 6:
- {
- if (!bRODoubleLines)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bDoubleLines;
- ++nRealCount;
- }
- }
- break;
-
- case 7:
- {
- if (!bROEmphasisMarks)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bEmphasisMarks;
- ++nRealCount;
- }
- }
- break;
-
- case 8:
- {
- if (!bROVerticalCallOut)
- {
- pNames[nRealCount] = pOrgNames[nProp];
- pValues[nRealCount] <<= bVerticalCallOut;
- ++nRealCount;
- }
- }
- break;
- }
- }
- aNames.realloc(nRealCount);
- aValues.realloc(nRealCount);
- PutProperties(aNames, aValues);
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::ChangeCaseMap::get();
}
-bool SvtCJKOptions_Impl::IsReadOnly(SvtCJKOptions::EOption eOption) const
+bool IsDoubleLinesEnabled()
{
- bool bReadOnly = CFG_READONLY_DEFAULT;
- switch(eOption)
- {
- case SvtCJKOptions::E_CJKFONT : bReadOnly = bROCJKFont; break;
- case SvtCJKOptions::E_VERTICALTEXT : bReadOnly = bROVerticalText; break;
- case SvtCJKOptions::E_ASIANTYPOGRAPHY : bReadOnly = bROAsianTypography; break;
- case SvtCJKOptions::E_JAPANESEFIND : bReadOnly = bROJapaneseFind; break;
- case SvtCJKOptions::E_RUBY : bReadOnly = bRORuby; break;
- case SvtCJKOptions::E_CHANGECASEMAP : bReadOnly = bROChangeCaseMap; break;
- case SvtCJKOptions::E_DOUBLELINES : bReadOnly = bRODoubleLines; break;
- case SvtCJKOptions::E_EMPHASISMARKS : bReadOnly = bROEmphasisMarks; break;
- case SvtCJKOptions::E_VERTICALCALLOUT : bReadOnly = bROVerticalCallOut; break;
- case SvtCJKOptions::E_ALL : if (bROCJKFont || bROVerticalText || bROAsianTypography || bROJapaneseFind || bRORuby || bROChangeCaseMap || bRODoubleLines || bROEmphasisMarks || bROVerticalCallOut)
- bReadOnly = true;
- break;
- }
- return bReadOnly;
+ SvtCJKOptions_Load();
+ return officecfg::Office::Common::I18N::CJK::DoubleLines::get();
}
-namespace {
-
- // global
- std::weak_ptr<SvtCJKOptions_Impl> g_pCJKOptions;
-
- struct theCJKOptionsMutex : public rtl::Static< ::osl::Mutex , theCJKOptionsMutex >{};
-}
-
-SvtCJKOptions::SvtCJKOptions(bool bDontLoad)
-{
- // Global access, must be guarded (multithreading)
- ::osl::MutexGuard aGuard( theCJKOptionsMutex::get() );
- pImpl = g_pCJKOptions.lock();
- if ( !pImpl )
- {
- pImpl = std::make_shared<SvtCJKOptions_Impl>();
- g_pCJKOptions = pImpl;
- ItemHolder2::holdConfigItem(EItem::CJKOptions);
- }
-
- if( !bDontLoad && !pImpl->IsLoaded())
- pImpl->Load();
-}
-
-
-SvtCJKOptions::~SvtCJKOptions()
+void SetAll(bool bSet)
{
- // Global access, must be guarded (multithreading)
- ::osl::MutexGuard aGuard( theCJKOptionsMutex::get() );
+ SvtCJKOptions_Load();
+ if ( officecfg::Office::Common::I18N::CJK::CJKFont::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::VerticalText::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::AsianTypography::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::JapaneseFind::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::Ruby::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::ChangeCaseMap::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::DoubleLines::isReadOnly() )
+ return;
- // pImpl needs to be cleared before the mutex is dropped
- pImpl.reset();
+ std::shared_ptr<comphelper::ConfigurationChanges> xChanges(comphelper::ConfigurationChanges::create());
+ officecfg::Office::Common::I18N::CJK::CJKFont::set(bSet, xChanges);
+ officecfg::Office::Common::I18N::CJK::VerticalText::set(bSet, xChanges);
+ officecfg::Office::Common::I18N::CJK::AsianTypography::set(bSet, xChanges);
+ officecfg::Office::Common::I18N::CJK::JapaneseFind::set(bSet, xChanges);
+ officecfg::Office::Common::I18N::CJK::Ruby::set(bSet, xChanges);
+ officecfg::Office::Common::I18N::CJK::ChangeCaseMap::set(bSet, xChanges);
+ officecfg::Office::Common::I18N::CJK::DoubleLines::set(bSet, xChanges);
+ xChanges->commit();
}
-bool SvtCJKOptions::IsCJKFontEnabled() const
+bool IsAnyEnabled()
{
- assert(pImpl->IsLoaded());
- return pImpl->IsCJKFontEnabled();
+ SvtCJKOptions_Load();
+ return IsCJKFontEnabled() || IsVerticalTextEnabled() || IsAsianTypographyEnabled() || IsJapaneseFindEnabled() ||
+ IsRubyEnabled() || IsChangeCaseMapEnabled() || IsDoubleLinesEnabled() ;
}
-bool SvtCJKOptions::IsVerticalTextEnabled() const
+bool IsReadOnly(EOption eOption)
{
- assert(pImpl->IsLoaded());
- return pImpl->IsVerticalTextEnabled();
+ SvtCJKOptions_Load();
+ switch (eOption)
+ {
+ case E_CJKFONT: return officecfg::Office::Common::I18N::CJK::CJKFont::isReadOnly();
+ case E_VERTICALTEXT: return officecfg::Office::Common::I18N::CJK::VerticalText::isReadOnly();
+ case E_ASIANTYPOGRAPHY: return officecfg::Office::Common::I18N::CJK::AsianTypography::isReadOnly();
+ case E_JAPANESEFIND: return officecfg::Office::Common::I18N::CJK::JapaneseFind::isReadOnly();
+ case E_RUBY: return officecfg::Office::Common::I18N::CJK::Ruby::isReadOnly();
+ case E_CHANGECASEMAP: return officecfg::Office::Common::I18N::CJK::ChangeCaseMap::isReadOnly();
+ case E_DOUBLELINES: return officecfg::Office::Common::I18N::CJK::DoubleLines::isReadOnly();
+ case E_ALL:
+ return officecfg::Office::Common::I18N::CJK::CJKFont::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::VerticalText::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::AsianTypography::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::JapaneseFind::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::Ruby::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::ChangeCaseMap::isReadOnly()
+ || officecfg::Office::Common::I18N::CJK::DoubleLines::isReadOnly();
+ default:
+ assert(false);
+ }
+ return false;
}
-bool SvtCJKOptions::IsAsianTypographyEnabled() const
-{
- assert(pImpl->IsLoaded());
- return pImpl->IsAsianTypographyEnabled();
-}
+} // namespace SvtCJKOptions
-bool SvtCJKOptions::IsJapaneseFindEnabled() const
-{
- assert(pImpl->IsLoaded());
- return pImpl->IsJapaneseFindEnabled();
-}
-bool SvtCJKOptions::IsRubyEnabled() const
-{
- assert(pImpl->IsLoaded());
- return pImpl->IsRubyEnabled();
-}
+static std::once_flag gLoadFlag;
-bool SvtCJKOptions::IsChangeCaseMapEnabled() const
+static void SvtCJKOptions_Load()
{
- assert(pImpl->IsLoaded());
- return pImpl->IsChangeCaseMapEnabled();
-}
+ std::call_once(gLoadFlag,
+ []()
+ {
+ if (officecfg::Office::Common::I18N::CJK::CJKFont::get())
+ return;
-bool SvtCJKOptions::IsDoubleLinesEnabled() const
-{
- assert(pImpl->IsLoaded());
- return pImpl->IsDoubleLinesEnabled();
-}
+ SvtScriptType nScriptType = SvtLanguageOptions::GetScriptTypeOfLanguage(LANGUAGE_SYSTEM);
+ //system locale is CJK
+ bool bAutoEnableCJK = bool(nScriptType & SvtScriptType::ASIAN);
-void SvtCJKOptions::SetAll(bool bSet)
-{
- assert(pImpl->IsLoaded());
- pImpl->SetAll(bSet);
-}
+ if (!bAutoEnableCJK)
+ {
+ //windows secondary system locale is CJK
+ OUString sWin16SystemLocale = officecfg::System::L10N::SystemLocale::get();
+ LanguageType eSystemLanguage = LANGUAGE_NONE;
+ if( !sWin16SystemLocale.isEmpty() )
+ eSystemLanguage = LanguageTag::convertToLanguageTypeWithFallback( sWin16SystemLocale );
+ if (eSystemLanguage != LANGUAGE_SYSTEM)
+ {
+ SvtScriptType nWinScript = SvtLanguageOptions::GetScriptTypeOfLanguage( eSystemLanguage );
+ bAutoEnableCJK = bool(nWinScript & SvtScriptType::ASIAN);
+ }
-bool SvtCJKOptions::IsAnyEnabled() const
-{
- assert(pImpl->IsLoaded());
- return pImpl->IsAnyEnabled();
-}
+ //CJK keyboard is installed
+ if (!bAutoEnableCJK)
+ bAutoEnableCJK = SvtSystemLanguageOptions::isCJKKeyboardLayoutInstalled();
+ }
-bool SvtCJKOptions::IsReadOnly(EOption eOption) const
-{
- assert(pImpl->IsLoaded());
- return pImpl->IsReadOnly(eOption);
+ if (bAutoEnableCJK)
+ {
+ std::shared_ptr<comphelper::ConfigurationChanges> xChanges(comphelper::ConfigurationChanges::create());
+ officecfg::Office::Common::I18N::CJK::CJKFont::set(true, xChanges);
+ officecfg::Office::Common::I18N::CJK::VerticalText::set(true, xChanges);
+ officecfg::Office::Common::I18N::CJK::AsianTypography::set(true, xChanges);
+ officecfg::Office::Common::I18N::CJK::JapaneseFind::set(true, xChanges);
+ officecfg::Office::Common::I18N::CJK::Ruby::set(true, xChanges);
+ officecfg::Office::Common::I18N::CJK::ChangeCaseMap::set(true, xChanges);
+ officecfg::Office::Common::I18N::CJK::DoubleLines::set(true, xChanges);
+ xChanges->commit();
+ }
+ });
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */