diff options
author | Noel Grandin <noel.grandin@collabora.co.uk> | 2018-07-16 10:00:54 +0200 |
---|---|---|
committer | Noel Grandin <noel.grandin@collabora.co.uk> | 2018-07-17 10:59:03 +0200 |
commit | d683ec33d478606fa8afc2d44d8f1282562e8dfa (patch) | |
tree | 7a4455b8132eeafb54f14b671bf675f9691601d6 /cui/source | |
parent | 5a74884e7da4c497c4ea714bf84d62b55ed82cfe (diff) |
loplugin:useuniqueptr in SvxAsianLayoutPage_Impl
Change-Id: I6380ccceabb9ce9c3c7c187e913e7384d8854b5b
Reviewed-on: https://gerrit.libreoffice.org/57516
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Diffstat (limited to 'cui/source')
-rw-r--r-- | cui/source/options/optasian.cxx | 41 |
1 files changed, 15 insertions, 26 deletions
diff --git a/cui/source/options/optasian.cxx b/cui/source/options/optasian.cxx index c2a5030b54d0..135cf9fdc1ff 100644 --- a/cui/source/options/optasian.cxx +++ b/cui/source/options/optasian.cxx @@ -50,33 +50,22 @@ struct SvxForbiddenChars_Impl std::unique_ptr<ForbiddenCharacters> pCharacters; }; -typedef std::map< LanguageType, SvxForbiddenChars_Impl* > SvxForbiddenCharacterMap_Impl; - struct SvxAsianLayoutPage_Impl { SvxAsianConfig aConfig; SvxAsianLayoutPage_Impl() {} - ~SvxAsianLayoutPage_Impl(); - Reference< XForbiddenCharacters > xForbidden; Reference< XPropertySet > xPrSet; Reference< XPropertySetInfo > xPrSetInfo; - SvxForbiddenCharacterMap_Impl aChangedLanguagesMap; + std::map< LanguageType, std::unique_ptr<SvxForbiddenChars_Impl> > + aChangedLanguagesMap; bool hasForbiddenCharacters(LanguageType eLang); SvxForbiddenChars_Impl* getForbiddenCharacters(LanguageType eLang); - void addForbiddenCharacters(LanguageType eLang, ForbiddenCharacters const * pForbidden); + void addForbiddenCharacters(LanguageType eLang, std::unique_ptr<ForbiddenCharacters> pForbidden); }; -SvxAsianLayoutPage_Impl::~SvxAsianLayoutPage_Impl() -{ - for (auto const& changedLanguage : aChangedLanguagesMap) - { - delete changedLanguage.second; - } -} - bool SvxAsianLayoutPage_Impl::hasForbiddenCharacters(LanguageType eLang) { return aChangedLanguagesMap.count( eLang ); @@ -84,28 +73,28 @@ bool SvxAsianLayoutPage_Impl::hasForbiddenCharacters(LanguageType eLang) SvxForbiddenChars_Impl* SvxAsianLayoutPage_Impl::getForbiddenCharacters(LanguageType eLang) { - SvxForbiddenCharacterMap_Impl::iterator it = aChangedLanguagesMap.find( eLang ); + auto it = aChangedLanguagesMap.find( eLang ); DBG_ASSERT( ( it != aChangedLanguagesMap.end() ), "language not available"); if( it != aChangedLanguagesMap.end() ) - return it->second; + return it->second.get(); return nullptr; } void SvxAsianLayoutPage_Impl::addForbiddenCharacters( - LanguageType eLang, ForbiddenCharacters const * pForbidden) + LanguageType eLang, std::unique_ptr<ForbiddenCharacters> pForbidden) { - SvxForbiddenCharacterMap_Impl::iterator itOld = aChangedLanguagesMap.find( eLang ); + auto itOld = aChangedLanguagesMap.find( eLang ); if( itOld == aChangedLanguagesMap.end() ) { - SvxForbiddenChars_Impl* pChar = new SvxForbiddenChars_Impl; + std::unique_ptr<SvxForbiddenChars_Impl> pChar(new SvxForbiddenChars_Impl); pChar->bRemoved = nullptr == pForbidden; - pChar->pCharacters.reset( pForbidden ? new ForbiddenCharacters(*pForbidden) : nullptr ); - aChangedLanguagesMap.insert( std::make_pair( eLang, pChar ) ); + pChar->pCharacters = std::move(pForbidden); + aChangedLanguagesMap.emplace( eLang, std::move(pChar) ); } else { itOld->second->bRemoved = nullptr == pForbidden; - itOld->second->pCharacters.reset( pForbidden ? new ForbiddenCharacters(*pForbidden) : nullptr ); + itOld->second->pCharacters = std::move(pForbidden); } } @@ -385,10 +374,10 @@ IMPL_LINK(SvxAsianLayoutPage, ModifyHdl, Edit&, rEdit, void) { if(bEnable) { - ForbiddenCharacters aSet; - aSet.beginLine = sStart; - aSet.endLine = sEnd; - pImpl->addForbiddenCharacters(eSelectLanguage, &aSet); + std::unique_ptr<ForbiddenCharacters> pFCSet(new ForbiddenCharacters); + pFCSet->beginLine = sStart; + pFCSet->endLine = sEnd; + pImpl->addForbiddenCharacters(eSelectLanguage, std::move(pFCSet)); } else pImpl->addForbiddenCharacters(eSelectLanguage, nullptr); |