office-gobmx/include/comphelper/weakeventlistener.hxx
Noel Grandin 5b2cd79ade loplugin:finalmethods
create a plugin that finds methods we can mark as final because they are
not override in subclasses.

Which is useful both as documentation (telling you that you don't need
to worry about subclasses changing the implementation under you),
and for performance, letting the compiler elide virtual calls in many
cases.

Apply the results to a subset of stuff in /include

Change-Id: I7b5cc893ec2f343bc356bfc338e4cf531ffba1e0
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/165054
Tested-by: Jenkins
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
2024-03-26 17:16:47 +01:00

181 lines
6 KiB
C++

/* -*- 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 .
*/
#ifndef INCLUDED_COMPHELPER_WEAKEVENTLISTENER_HXX
#define INCLUDED_COMPHELPER_WEAKEVENTLISTENER_HXX
#include <config_options.h>
#include <comphelper/compbase.hxx>
#include <cppuhelper/weakref.hxx>
#include <comphelper/comphelperdllapi.h>
#include <com/sun/star/lang/XEventListener.hpp>
#include <com/sun/star/lang/XComponent.hpp>
#include <utility>
namespace com::sun::star::uno { class XWeak; }
namespace comphelper
{
//= OWeakListenerAdapterBase
/** (the base for) an adapter which allows to add as listener to a foreign component, without
being held hard.
<p>The idea is that this adapter is added as listener to a foreign component, which usually
holds it's listener hard. The adapter itself knows the real listener as weak reference,
thus not affecting its life time.</p>
*/
class OWeakListenerAdapterBase
{
private:
css::uno::WeakReference< css::uno::XInterface >
m_aListener;
css::uno::Reference< css::uno::XInterface >
m_xBroadcaster;
protected:
css::uno::Reference< css::uno::XInterface >
getListener( ) const
{
return m_aListener.get();
}
const css::uno::Reference< css::uno::XInterface >&
getBroadcaster( ) const
{
return m_xBroadcaster;
}
void resetListener( )
{
m_aListener.clear();
}
protected:
OWeakListenerAdapterBase(
const css::uno::Reference< css::uno::XWeak >& _rxListener,
css::uno::Reference< css::uno::XInterface > _xBroadcaster
)
:m_aListener ( _rxListener )
,m_xBroadcaster (std::move( _xBroadcaster ))
{
}
protected:
virtual ~OWeakListenerAdapterBase();
};
//= OWeakListenerAdapter
template< class BROADCASTER, class LISTENER >
/** yet another base for weak listener adapters, this time with some type safety
<p>Note that derived classes need to overwrite all virtual methods of their interface
except XEventListener::disposing, and forward it to their master listener.</p>
<p>Additionally, derived classes need to add themself as listener to the broadcaster,
as this can't be done in a generic way</p>
*/
class OWeakListenerAdapter
:public ::comphelper::WeakComponentImplHelper< LISTENER >
,public OWeakListenerAdapterBase
{
protected:
/** ctor
<p>Note that derived classes still need to add themself as listener to the broadcaster,
as this can't be done in a generic way</p>
*/
OWeakListenerAdapter(
const css::uno::Reference< css::uno::XWeak >& _rxListener,
const css::uno::Reference< BROADCASTER >& _rxBroadcaster
);
protected:
css::uno::Reference< LISTENER > getListener( ) const
{
return css::uno::Reference< LISTENER >( OWeakListenerAdapterBase::getListener(), css::uno::UNO_QUERY );
}
// XEventListener overridables
virtual void SAL_CALL disposing( const css::lang::EventObject& Source ) override final;
protected:
// OComponentHelper overridables
// to be overridden, again - the derived class should revoke the listener from the broadcaster
virtual void disposing( std::unique_lock<std::mutex>& rGuard ) override = 0;
};
//= OWeakEventListenerAdapter
typedef OWeakListenerAdapter < css::lang::XComponent
, css::lang::XEventListener
> OWeakEventListenerAdapter_Base;
/** the most simple listener adapter: for XEventListeners at XComponents
*/
class UNLESS_MERGELIBS(COMPHELPER_DLLPUBLIC) OWeakEventListenerAdapter final : public OWeakEventListenerAdapter_Base
{
public:
OWeakEventListenerAdapter(
css::uno::Reference< css::uno::XWeak > const & _rxListener,
css::uno::Reference< css::lang::XComponent > const & _rxBroadcaster
);
// nothing to do except an own ctor - the forwarding of the "disposing" is already done
// in the base class
private:
using OWeakEventListenerAdapter_Base::disposing;
virtual void disposing( std::unique_lock<std::mutex>& rGuard ) override;
};
//= OWeakListenerAdapter
template< class BROADCASTER, class LISTENER >
OWeakListenerAdapter< BROADCASTER, LISTENER >::OWeakListenerAdapter(
const css::uno::Reference< css::uno::XWeak >& _rxListener,
const css::uno::Reference< BROADCASTER >& _rxBroadcaster
)
: OWeakListenerAdapterBase( _rxListener, _rxBroadcaster )
{
}
template< class BROADCASTER, class LISTENER >
void SAL_CALL OWeakListenerAdapter< BROADCASTER, LISTENER >::disposing( const css::lang::EventObject& _rSource )
{
css::uno::Reference< LISTENER > xListener( getListener() );
if ( xListener.is() )
xListener->disposing( _rSource );
}
} // namespace comphelper
#endif // INCLUDED_COMPHELPER_WEAKEVENTLISTENER_HXX
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */