LibreOffice Module comphelper (master)  1
Classes | Public Member Functions | Private Member Functions | Private Attributes | Friends | List of all members
comphelper::OInterfaceContainerHelper4< ListenerT > Class Template Reference

A container of interfaces. More...

#include <interfacecontainer4.hxx>

Inheritance diagram for comphelper::OInterfaceContainerHelper4< ListenerT >:
[legend]
Collaboration diagram for comphelper::OInterfaceContainerHelper4< ListenerT >:
[legend]

Classes

class  NotifySingleListener
 

Public Member Functions

 OInterfaceContainerHelper4 ()
 
sal_Int32 getLength () const
 Return the number of Elements in the container. More...
 
std::vector< css::uno::Reference< ListenerT > > getElements () const
 Return all interfaces added to this container. More...
 
sal_Int32 addInterface (const css::uno::Reference< ListenerT > &rxIFace)
 Inserts an element into the container. More...
 
sal_Int32 removeInterface (const css::uno::Reference< ListenerT > &rxIFace)
 Removes an element from the container. More...
 
void disposeAndClear (::std::unique_lock<::std::mutex > &rGuard, const css::lang::EventObject &rEvt)
 Call disposing on all object in the container that support XEventListener. More...
 
void clear ()
 Clears the container without calling disposing(). More...
 
template<typename FuncT >
void forEach (FuncT const &func)
 Executes a functor for each contained listener of specified type, e.g. More...
 
template<typename EventT >
void notifyEach (void(SAL_CALL ListenerT::*NotificationMethod)(const EventT &), const EventT &Event)
 Calls a UNO listener method for each contained listener. More...
 

Private Member Functions

 OInterfaceContainerHelper4 (const OInterfaceContainerHelper4 &)=delete
 
OInterfaceContainerHelper4operator= (const OInterfaceContainerHelper4 &)=delete
 

Private Attributes

o3tl::cow_wrapper< std::vector< css::uno::Reference< ListenerT > > > maData
 

Friends

class OInterfaceIteratorHelper4< ListenerT >
 

Detailed Description

template<class ListenerT>
class comphelper::OInterfaceContainerHelper4< ListenerT >

A container of interfaces.

To access the elements use an iterator. This implementation is thread-safe.

This is a copy of the code at include/comphelper/interfacecontainer3.hxx, except that it (a) uses std::mutex instead of osl::Mutex and (b) does not store a reference to the mutex, but relies on the calling class to take a lock around using it.

Template Parameters
ListenerTUNO event listener type
See also
OInterfaceIteratorHelper

Definition at line 38 of file interfacecontainer4.hxx.

Constructor & Destructor Documentation

template<class ListenerT>
comphelper::OInterfaceContainerHelper4< ListenerT >::OInterfaceContainerHelper4 ( )
inline

Definition at line 119 of file interfacecontainer4.hxx.

template<class ListenerT>
comphelper::OInterfaceContainerHelper4< ListenerT >::OInterfaceContainerHelper4 ( const OInterfaceContainerHelper4< ListenerT > &  )
privatedelete

Member Function Documentation

template<class ListenerT>
sal_Int32 comphelper::OInterfaceContainerHelper4< ListenerT >::addInterface ( const css::uno::Reference< ListenerT > &  rxIFace)

Inserts an element into the container.

The position is not specified, thus it is not specified in which order events are fired.

Attention:

If you add the same interface more than once, then it will be added to the elements list more than once and thus if you want to remove that interface from the list, you have to call removeInterface() the same number of times. In the latter case, you will also get events fired more than once (if the interface is a listener interface).

Parameters
rxIFaceinterface to be added; it is allowed to insert the same interface more than once
Returns
the new count of elements in the container

Definition at line 274 of file interfacecontainer4.hxx.

References maData.

Referenced by OInstanceLocker::addEventListener().

template<class ListenerT >
void comphelper::OInterfaceContainerHelper4< ListenerT >::clear ( )

Clears the container without calling disposing().

Definition at line 324 of file interfacecontainer4.hxx.

References maData.

template<class ListenerT>
void comphelper::OInterfaceContainerHelper4< ListenerT >::disposeAndClear ( ::std::unique_lock<::std::mutex > &  rGuard,
const css::lang::EventObject &  rEvt 
)

Call disposing on all object in the container that support XEventListener.

Then clear the container. The guard is unlock()'ed before calling the listeners.

Definition at line 304 of file interfacecontainer4.hxx.

References comphelper::OInterfaceIteratorHelper4< ListenerT >::hasMoreElements(), maData, and comphelper::OInterfaceIteratorHelper4< ListenerT >::next().

Referenced by OInstanceLocker::dispose().

template<class T >
template<typename FuncT >
void comphelper::OInterfaceContainerHelper4< T >::forEach ( FuncT const &  func)
inline

Executes a functor for each contained listener of specified type, e.g.

forEach<awt::XPaintListener>(....

If a css::lang::DisposedException occurs which relates to the called listener, then that listener is removed from the container.

Template Parameters
FuncTunary functor type, let your compiler deduce this for you
Parameters
funcunary functor object expecting an argument of type css::uno::Reference<ListenerT>

Definition at line 234 of file interfacecontainer4.hxx.

References comphelper::OInterfaceIteratorHelper4< ListenerT >::hasMoreElements(), comphelper::OInterfaceIteratorHelper4< ListenerT >::next(), and comphelper::OInterfaceIteratorHelper4< ListenerT >::remove().

template<class ListenerT >
std::vector< css::uno::Reference< ListenerT > > comphelper::OInterfaceContainerHelper4< ListenerT >::getElements ( ) const

Return all interfaces added to this container.

Definition at line 267 of file interfacecontainer4.hxx.

References maData.

template<class ListenerT >
sal_Int32 comphelper::OInterfaceContainerHelper4< ListenerT >::getLength ( ) const

Return the number of Elements in the container.

Only useful if you have acquired the mutex.

Definition at line 260 of file interfacecontainer4.hxx.

References maData.

template<class ListenerT>
template<typename EventT >
void comphelper::OInterfaceContainerHelper4< ListenerT >::notifyEach ( void(SAL_CALL ListenerT::*)(const EventT &)  NotificationMethod,
const EventT &  Event 
)
inline

Calls a UNO listener method for each contained listener.

The listener method must take a single argument of type EventT, and return void.

If a css::lang::DisposedException occurs which relates to the called listener, then that listener is removed from the container.

Template Parameters
EventTevent type, let your compiler deduce this for you
Parameters
NotificationMethodPointer to a method of a ListenerT interface.
EventEvent to notify to all contained listeners

Example:

awt::PaintEvent aEvent( static_cast< cppu::OWeakObject* >( this ), ... );
listeners.notifyEach( &XPaintListener::windowPaint, aEvent );

Definition at line 254 of file interfacecontainer4.hxx.

template<class ListenerT>
OInterfaceContainerHelper4& comphelper::OInterfaceContainerHelper4< ListenerT >::operator= ( const OInterfaceContainerHelper4< ListenerT > &  )
privatedelete
template<class ListenerT>
sal_Int32 comphelper::OInterfaceContainerHelper4< ListenerT >::removeInterface ( const css::uno::Reference< ListenerT > &  rxIFace)

Removes an element from the container.

It uses interface equality to remove the interface.

Parameters
rxIFaceinterface to be removed
Returns
the new count of elements in the container

Definition at line 282 of file interfacecontainer4.hxx.

References find(), and maData.

Referenced by OInstanceLocker::removeEventListener().

Friends And Related Function Documentation

template<class ListenerT>
friend class OInterfaceIteratorHelper4< ListenerT >
friend

Definition at line 205 of file interfacecontainer4.hxx.

Member Data Documentation

template<class ListenerT>
o3tl::cow_wrapper<std::vector<css::uno::Reference<ListenerT> > > comphelper::OInterfaceContainerHelper4< ListenerT >::maData
private

Definition at line 206 of file interfacecontainer4.hxx.


The documentation for this class was generated from the following file: