/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include "linguistic/misc.hxx" #include "sprophelp.hxx" #include "linguistic/lngprops.hxx" #include #include #include #include #include using namespace osl; using namespace com::sun::star; using namespace com::sun::star::beans; using namespace com::sun::star::lang; using namespace com::sun::star::uno; using namespace com::sun::star::linguistic2; using namespace linguistic; PropertyChgHelper::PropertyChgHelper( const Reference< XInterface > & rxSource, Reference< XPropertySet > &rxPropSet, const char *pPropNames[], sal_uInt16 nPropCount ) : aPropNames(nPropCount) , xMyEvtObj(rxSource) , aLngSvcEvtListeners(GetLinguMutex()) , xPropSet(rxPropSet) { OUString *pName = aPropNames.getArray(); for (sal_Int32 i = 0; i < nPropCount; ++i) { pName[i] = OUString::createFromAscii( pPropNames[i] ); } } PropertyChgHelper::PropertyChgHelper( const PropertyChgHelper &rHelper ) : aPropNames(rHelper.aPropNames), xMyEvtObj(rHelper.xMyEvtObj), aLngSvcEvtListeners (GetLinguMutex()), xPropSet(rHelper.xPropSet) { AddAsPropListener(); } PropertyChgHelper::~PropertyChgHelper() { } void PropertyChgHelper::AddAsPropListener() { if (xPropSet.is()) { sal_Int32 nLen = aPropNames.getLength(); const OUString *pPropName = aPropNames.getConstArray(); for (sal_Int32 i = 0; i < nLen; ++i) { if (pPropName[i].getLength()) xPropSet->addPropertyChangeListener( pPropName[i], this ); } } } void PropertyChgHelper::RemoveAsPropListener() { if (xPropSet.is()) { sal_Int32 nLen = aPropNames.getLength(); const OUString *pPropName = aPropNames.getConstArray(); for (sal_Int32 i = 0; i < nLen; ++i) { if (pPropName[i].getLength()) xPropSet->removePropertyChangeListener( pPropName[i], this ); } } } void PropertyChgHelper::LaunchEvent( const LinguServiceEvent &rEvt ) { cppu::OInterfaceIteratorHelper aIt( aLngSvcEvtListeners ); while (aIt.hasMoreElements()) { Reference< XLinguServiceEventListener > xRef( aIt.next(), UNO_QUERY ); if (xRef.is()) xRef->processLinguServiceEvent( rEvt ); } } void SAL_CALL PropertyChgHelper::disposing( const EventObject& rSource ) throw(RuntimeException) { MutexGuard aGuard( GetLinguMutex() ); if (rSource.Source == xPropSet) { RemoveAsPropListener(); xPropSet = NULL; aPropNames.realloc( 0 ); } } sal_Bool SAL_CALL PropertyChgHelper::addLinguServiceEventListener( const Reference< XLinguServiceEventListener >& rxListener ) throw(RuntimeException) { MutexGuard aGuard( GetLinguMutex() ); sal_Bool bRes = sal_False; if (rxListener.is()) { sal_Int32 nCount = aLngSvcEvtListeners.getLength(); bRes = aLngSvcEvtListeners.addInterface( rxListener ) != nCount; } return bRes; } sal_Bool SAL_CALL PropertyChgHelper::removeLinguServiceEventListener( const Reference< XLinguServiceEventListener >& rxListener ) throw(RuntimeException) { MutexGuard aGuard( GetLinguMutex() ); sal_Bool bRes = sal_False; if (rxListener.is()) { sal_Int32 nCount = aLngSvcEvtListeners.getLength(); bRes = aLngSvcEvtListeners.removeInterface( rxListener ) != nCount; } return bRes; } static const char *aSP[] = { UPN_IS_GERMAN_PRE_REFORM, UPN_IS_IGNORE_CONTROL_CHARACTERS, UPN_IS_USE_DICTIONARY_LIST, UPN_IS_SPELL_UPPER_CASE, UPN_IS_SPELL_WITH_DIGITS, UPN_IS_SPELL_CAPITALIZATION, UPN_IS_SPELL_CLOSED_COMPOUND, UPN_IS_SPELL_HYPHENATED_COMPOUND }; PropertyHelper_Spell::PropertyHelper_Spell( const Reference< XInterface > & rxSource, Reference< XPropertySet > &rxPropSet ) : PropertyChgHelper ( rxSource, rxPropSet, aSP, SAL_N_ELEMENTS(aSP) ) { SetDefault(); sal_Int32 nLen = GetPropNames().getLength(); if (rxPropSet.is() && nLen) { const OUString *pPropName = GetPropNames().getConstArray(); for (sal_Int32 i = 0; i < nLen; ++i) { sal_Bool *pbVal = NULL, *pbResVal = NULL; if (OUString( UPN_IS_GERMAN_PRE_REFORM ) == pPropName[i]) { pbVal = &bIsGermanPreReform; pbResVal = &bResIsGermanPreReform; } else if (OUString( UPN_IS_IGNORE_CONTROL_CHARACTERS ) == pPropName[i]) { pbVal = &bIsIgnoreControlCharacters; pbResVal = &bResIsIgnoreControlCharacters; } else if (OUString( UPN_IS_USE_DICTIONARY_LIST ) == pPropName[i]) { pbVal = &bIsUseDictionaryList; pbResVal = &bResIsUseDictionaryList; } else if (OUString( UPN_IS_SPELL_UPPER_CASE ) == pPropName[i]) { pbVal = &bIsSpellUpperCase; pbResVal = &bResIsSpellUpperCase; } else if (OUString( UPN_IS_SPELL_WITH_DIGITS ) == pPropName[i]) { pbVal = &bIsSpellWithDigits; pbResVal = &bResIsSpellWithDigits; } else if (OUString( UPN_IS_SPELL_CAPITALIZATION ) == pPropName[i]) { pbVal = &bIsSpellCapitalization; pbResVal = &bResIsSpellCapitalization; } else if (OUString( UPN_IS_SPELL_CLOSED_COMPOUND ) == pPropName[i]) { pbVal = &bIsSpellClosedCompound; pbResVal = &bResIsSpellClosedCompound; } else if (OUString( UPN_IS_SPELL_HYPHENATED_COMPOUND ) == pPropName[i]) { pbVal = &bIsSpellHyphenatedCompound; pbResVal = &bResIsSpellHyphenatedCompound; } if (pbVal && pbResVal) { rxPropSet->getPropertyValue( pPropName[i] ) >>= *pbVal; *pbResVal = *pbVal; } } } } PropertyHelper_Spell::~PropertyHelper_Spell() { } void PropertyHelper_Spell::SetDefault() { bResIsGermanPreReform = bIsGermanPreReform = sal_False; bResIsIgnoreControlCharacters = bIsIgnoreControlCharacters = sal_True; bResIsUseDictionaryList = bIsUseDictionaryList = sal_True; bResIsSpellUpperCase = bIsSpellUpperCase = sal_False; bResIsSpellWithDigits = bIsSpellWithDigits = sal_False; bResIsSpellCapitalization = bIsSpellCapitalization = sal_True; bResIsSpellClosedCompound = bIsSpellClosedCompound = sal_True; bResIsSpellHyphenatedCompound = bIsSpellHyphenatedCompound = sal_True; } void SAL_CALL PropertyHelper_Spell::propertyChange( const PropertyChangeEvent& rEvt ) throw(RuntimeException) { MutexGuard aGuard( GetLinguMutex() ); if (GetPropSet().is() && rEvt.Source == GetPropSet()) { sal_Int16 nLngSvcFlags = 0; sal_Bool bSCWA = sal_False, // SPELL_CORRECT_WORDS_AGAIN ? bSWWA = sal_False; // SPELL_WRONG_WORDS_AGAIN ? sal_Bool *pbVal = NULL; switch (rEvt.PropertyHandle) { case UPH_IS_IGNORE_CONTROL_CHARACTERS : { pbVal = &bIsIgnoreControlCharacters; break; } case UPH_IS_GERMAN_PRE_REFORM : { pbVal = &bIsGermanPreReform; bSCWA = bSWWA = sal_True; break; } case UPH_IS_USE_DICTIONARY_LIST : { pbVal = &bIsUseDictionaryList; bSCWA = bSWWA = sal_True; break; } case UPH_IS_SPELL_UPPER_CASE : { pbVal = &bIsSpellUpperCase; bSCWA = sal_False == *pbVal; // sal_False->sal_True change? bSWWA = !bSCWA; // sal_True->sal_False change? break; } case UPH_IS_SPELL_WITH_DIGITS : { pbVal = &bIsSpellWithDigits; bSCWA = sal_False == *pbVal; // sal_False->sal_True change? bSWWA = !bSCWA; // sal_True->sal_False change? break; } case UPH_IS_SPELL_CAPITALIZATION : { pbVal = &bIsSpellCapitalization; bSCWA = sal_False == *pbVal; // sal_False->sal_True change? bSWWA = !bSCWA; // sal_True->sal_False change? break; } case UPH_IS_SPELL_CLOSED_COMPOUND : { pbVal = &bIsSpellClosedCompound; bSCWA = sal_False == *pbVal; // sal_False->sal_True change? bSWWA = !bSCWA; // sal_True->sal_False change? break; } case UPH_IS_SPELL_HYPHENATED_COMPOUND : { pbVal = &bIsSpellHyphenatedCompound; bSCWA = sal_False == *pbVal; // sal_False->sal_True change? bSWWA = !bSCWA; // sal_True->sal_False change? break; } default: OSL_FAIL( "unknown property" ); } if (pbVal) rEvt.NewValue >>= *pbVal; if (bSCWA) nLngSvcFlags |= LinguServiceEventFlags::SPELL_CORRECT_WORDS_AGAIN; if (bSWWA) nLngSvcFlags |= LinguServiceEventFlags::SPELL_WRONG_WORDS_AGAIN; if (nLngSvcFlags) { LinguServiceEvent aEvt( GetEvtObj(), nLngSvcFlags ); LaunchEvent( aEvt ); } } } void PropertyHelper_Spell::SetTmpPropVals( const PropertyValues &rPropVals ) { // set return value to default value unless there is an // explicitly supplied temporary value bResIsGermanPreReform = bIsGermanPreReform; bResIsIgnoreControlCharacters = bIsIgnoreControlCharacters; bResIsUseDictionaryList = bIsUseDictionaryList; bResIsSpellUpperCase = bIsSpellUpperCase; bResIsSpellWithDigits = bIsSpellWithDigits; bResIsSpellCapitalization = bIsSpellCapitalization; bResIsSpellClosedCompound = bIsSpellClosedCompound; bResIsSpellHyphenatedCompound = bIsSpellHyphenatedCompound; sal_Int32 nLen = rPropVals.getLength(); if (nLen) { const PropertyValue *pVal = rPropVals.getConstArray(); for (sal_Int32 i = 0; i < nLen; ++i) { sal_Bool *pbResVal = NULL; switch (pVal[i].Handle) { case UPH_IS_GERMAN_PRE_REFORM : pbResVal = &bResIsGermanPreReform; break; case UPH_IS_IGNORE_CONTROL_CHARACTERS : pbResVal = &bResIsIgnoreControlCharacters; break; case UPH_IS_USE_DICTIONARY_LIST : pbResVal = &bResIsUseDictionaryList; break; case UPH_IS_SPELL_UPPER_CASE : pbResVal = &bResIsSpellUpperCase; break; case UPH_IS_SPELL_WITH_DIGITS : pbResVal = &bResIsSpellWithDigits; break; case UPH_IS_SPELL_CAPITALIZATION : pbResVal = &bResIsSpellCapitalization; break; case UPH_IS_SPELL_CLOSED_COMPOUND : pbResVal = &bResIsSpellClosedCompound; break; case UPH_IS_SPELL_HYPHENATED_COMPOUND : pbResVal = &bResIsSpellHyphenatedCompound; break; default: OSL_FAIL( "unknown property" ); } if (pbResVal) pVal[i].Value >>= *pbResVal; } } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ /option> LibreOffice 核心代码仓库文档基金会
summaryrefslogtreecommitdiff
t in compiler on macos-clang-intel
AgeCommit message (Expand)Author
Christian Lohmaier
2024-05-20loplugin:ostr in variousNoel Grandin
2023-11-19Extended loplugin:ostr: openclStephan Bergmann
2023-04-10Drop SvStream::WriteCharPtrMike Kaganski
2023-03-27loplugin:stringadd in oox..pyunoNoel Grandin
2023-02-03Use raw string literal in opencl to keep PMD static analyser happyIlmari Lauhakangas
2022-07-06opencl: no need for unhelpful nullptr OUString * case.Michael Meeks
2022-04-13loplugin:stringviewparam whitelist some more functionsNoel Grandin
2022-04-11loplugin:stringview add check for getToken().toInt32Noel Grandin
2022-01-30Recheck modules [o-r]* with IWYUGabor Kelemen
2021-10-30Prepare for removal of non-const operator[] from Sequence in openclMike Kaganski
2021-10-20loplugin:indentation check for indent inside blockNoel Grandin
2021-10-05drop 'using namespace std' in o* r* x*Julien Nabet
2021-08-20New loplugin:unusedcapturedefaultStephan Bergmann
2021-08-18loplugin:constparamsNoel Grandin
2021-04-27use more string_view in tools/streamNoel Grandin
2021-02-11Update OpenCL denylist and allowlistIlmari Lauhakangas
2021-01-28simplify code, use more subView()Noel
2020-12-29loplugin:stringviewparam: operator +Stephan Bergmann
2020-12-11Adapt the remaining OUString functions to std string_viewStephan Bergmann
2020-11-24loplugin:stringviewparam extend to comparison operatorsNoel
2020-11-19tdf#123936 Formatting files in module opencl with clang-formatPhilipp Hofer
2020-11-11convert more long -> tools::LongNoel
2020-08-30Goodbye O[U]StringView, welcome O[U]String::ConcatStephan Bergmann
2020-07-10replace usage of whitelist with allowlistThorsten Behrens
2020-07-10replace usage of blacklist with denylistThorsten Behrens
2020-04-03loplugin:flatten in openclNoel Grandin
2020-02-07merge OpenGLZone and OpenCLZone into one generic codeLuboš Luňák
2020-01-28New loplugin:unsignedcompareStephan Bergmann