diff options
-rw-r--r-- | configmgr/source/configurationprovider.cxx | 59 |
1 files changed, 28 insertions, 31 deletions
diff --git a/configmgr/source/configurationprovider.cxx b/configmgr/source/configurationprovider.cxx index b8bdcb4262f2..ddff084a1b03 100644 --- a/configmgr/source/configurationprovider.cxx +++ b/configmgr/source/configurationprovider.cxx @@ -39,8 +39,7 @@ #include <com/sun/star/util/XRefreshListener.hpp> #include <com/sun/star/util/XRefreshable.hpp> #include <cppu/unotype.hxx> -#include <cppuhelper/basemutex.hxx> -#include <cppuhelper/compbase.hxx> +#include <comphelper/compbase.hxx> #include <cppuhelper/supportsservice.hxx> #include <cppuhelper/weak.hxx> #include <osl/mutex.hxx> @@ -74,19 +73,18 @@ void badNodePath() { } typedef - cppu::WeakComponentImplHelper< + comphelper::WeakComponentImplHelper< css::lang::XServiceInfo, css::lang::XMultiServiceFactory, css::util::XRefreshable, css::util::XFlushable, css::lang::XLocalizable > ServiceBase; -class Service: - private cppu::BaseMutex, public ServiceBase +class Service : public ServiceBase { public: explicit Service( const css::uno::Reference< css::uno::XComponentContext >& context): - ServiceBase(m_aMutex), context_(context), default_(true), + context_(context), default_(true), lock_( lock() ) { assert(context.is()); @@ -95,7 +93,7 @@ public: Service( const css::uno::Reference< css::uno::XComponentContext >& context, OUString locale): - ServiceBase(m_aMutex), context_(context), locale_(std::move(locale)), + context_(context), locale_(std::move(locale)), default_(false), lock_( lock() ) { @@ -108,7 +106,7 @@ private: virtual ~Service() override {} - virtual void SAL_CALL disposing() override { flushModifications(); } + virtual void disposing(std::unique_lock<std::mutex>& rGuard) override { flushModifications(rGuard); } virtual OUString SAL_CALL getImplementationName() override { @@ -159,12 +157,14 @@ private: virtual css::lang::Locale SAL_CALL getLocale() override; - void flushModifications() const; + void flushModifications(std::unique_lock<std::mutex>& rGuard) const; css::uno::Reference< css::uno::XComponentContext > context_; OUString locale_; bool default_; std::shared_ptr<osl::Mutex> lock_; + comphelper::OInterfaceContainerHelper4<css::util::XRefreshListener> maRefreshListeners; + comphelper::OInterfaceContainerHelper4<css::util::XFlushListener> maFlushListeners; }; css::uno::Reference< css::uno::XInterface > Service::createInstance( @@ -271,49 +271,48 @@ css::uno::Sequence< OUString > Service::getAvailableServiceNames() void Service::refresh() { //TODO - cppu::OInterfaceContainerHelper * cont = rBHelper.getContainer( - cppu::UnoType< css::util::XRefreshListener >::get()); - if (cont != nullptr) { + std::unique_lock g(m_aMutex); + if (maRefreshListeners.getLength(g)) { css::lang::EventObject ev(static_cast< cppu::OWeakObject * >(this)); - cont->notifyEach(&css::util::XRefreshListener::refreshed, ev); + maRefreshListeners.notifyEach(g, &css::util::XRefreshListener::refreshed, ev); } } void Service::addRefreshListener( css::uno::Reference< css::util::XRefreshListener > const & l) { - rBHelper.addListener( - cppu::UnoType< css::util::XRefreshListener >::get(), l); + std::unique_lock g(m_aMutex); + maRefreshListeners.addInterface(g, l); } void Service::removeRefreshListener( css::uno::Reference< css::util::XRefreshListener > const & l) { - rBHelper.removeListener( - cppu::UnoType< css::util::XRefreshListener >::get(), l); + std::unique_lock g(m_aMutex); + maRefreshListeners.removeInterface(g, l); } void Service::flush() { - flushModifications(); - cppu::OInterfaceContainerHelper * cont = rBHelper.getContainer( - cppu::UnoType< css::util::XFlushListener >::get()); - if (cont != nullptr) { + std::unique_lock g(m_aMutex); + flushModifications(g); + if (maFlushListeners.getLength(g)) { css::lang::EventObject ev(static_cast< cppu::OWeakObject * >(this)); - cont->notifyEach(&css::util::XFlushListener::flushed, ev); + maFlushListeners.notifyEach(g, &css::util::XFlushListener::flushed, ev); } } void Service::addFlushListener( css::uno::Reference< css::util::XFlushListener > const & l) { - rBHelper.addListener(cppu::UnoType< css::util::XFlushListener >::get(), l); + std::unique_lock g(m_aMutex); + maFlushListeners.addInterface(g, l); } void Service::removeFlushListener( css::uno::Reference< css::util::XFlushListener > const & l) { - rBHelper.removeListener( - cppu::UnoType< css::util::XFlushListener >::get(), l); + std::unique_lock g(m_aMutex); + maFlushListeners.removeInterface(g, l); } void Service::setLocale(css::lang::Locale const & eLocale) @@ -331,13 +330,11 @@ css::lang::Locale Service::getLocale() { return loc; } -void Service::flushModifications() const { - Components * components; - { - osl::MutexGuard guard(*lock_); - components = &Components::getSingleton(context_); - } +void Service::flushModifications(std::unique_lock<std::mutex>& rGuard) const { + Components * components = &Components::getSingleton(context_); + rGuard.unlock(); components->flushModifications(); + rGuard.lock(); } extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface* |