c++-gtk-utils
Public Member Functions | List of all members
Cgu::Callback::Callback_memfun_tuple< T, MemFunc, Tuple, FreeArgs > Class Template Reference

#include <callback.h>

Inheritance diagram for Cgu::Callback::Callback_memfun_tuple< T, MemFunc, Tuple, FreeArgs >:
Cgu::Callback::CallbackArg< FreeArgs... >

Public Member Functions

void dispatch (typename Cgu::Param< FreeArgs >::ParamType... free_args) const
 
template<class... Args>
 Callback_memfun_tuple (T &obj_, MemFunc func_, Args &&... args)
 
- Public Member Functions inherited from Cgu::Callback::CallbackArg< FreeArgs... >
 CallbackArg ()
 
virtual ~CallbackArg ()
 

Constructor & Destructor Documentation

◆ Callback_memfun_tuple()

template<class T , class MemFunc , class Tuple , class... FreeArgs>
template<class... Args>
Cgu::Callback::Callback_memfun_tuple< T, MemFunc, Tuple, FreeArgs >::Callback_memfun_tuple ( T &  obj_,
MemFunc  func_,
Args &&...  args 
)
inline

Member Function Documentation

◆ dispatch()

template<class T , class MemFunc , class Tuple , class... FreeArgs>
void Cgu::Callback::Callback_memfun_tuple< T, MemFunc, Tuple, FreeArgs >::dispatch ( typename Cgu::Param< FreeArgs >::ParamType...  args) const
inlinevirtual

This will execute the referenced function, callable object or class method encapsulated by this class. It will only throw if the dispatched function, callable object or class method throws, or if the copy constructor of a free or bound argument throws and it is not a reference argument. It is thread safe if the referenced function or class method is thread safe.

Parameters
argsThe unbound arguments to be passed to the referenced function, callable object or class method, if any.
Note
We use dispatch() to execute the callback, because the callback would normally be invoked through a base class pointer. To invoke it through operator()(), use the FunctorArg or SafeFunctorArg wrapper class.

Implements Cgu::Callback::CallbackArg< FreeArgs... >.


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