[libsigc++2/variadic_bind3: 13/45] signal1/2/3/etc: Make this variadic.
- From: Murray Cumming <murrayc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libsigc++2/variadic_bind3: 13/45] signal1/2/3/etc: Make this variadic.
- Date: Wed, 2 Mar 2016 13:42:33 +0000 (UTC)
commit ec287e8fad4fe2c0c5ba0e3b3a0231a9fe4f679f
Author: Murray Cumming <murrayc murrayc com>
Date: Thu Jan 14 12:37:01 2016 +0100
signal1/2/3/etc: Make this variadic.
Though the separate generated signal1/2/3/etc still exist.
sigc++/macros/signal.h.m4 | 27 +++++++++++++--------------
1 files changed, 13 insertions(+), 14 deletions(-)
---
diff --git a/sigc++/macros/signal.h.m4 b/sigc++/macros/signal.h.m4
index 1c86287..f148594 100644
--- a/sigc++/macros/signal.h.m4
+++ b/sigc++/macros/signal.h.m4
@@ -49,14 +49,14 @@ FOR(1,$1,[
*
* @ingroup signal
*/
-template <LIST(class T_return, class T_accumulator, LOOP(class T_arg%1, $1))>
+template <class T_return, class T_accumulator, class... T_arg>
class signal$1
: public signal_base
{
public:
- typedef internal::signal_emit<LIST(T_return, T_accumulator, LOOP(T_arg%1, $1))> emitter_type;
+ typedef internal::signal_emit<LIST(T_return, T_accumulator, T_arg...)> emitter_type;
typedef typename emitter_type::result_type result_type;
- typedef slot<LIST(T_return, LOOP(T_arg%1, $1))> slot_type;
+ typedef slot<T_return, T_arg...> slot_type;
typedef slot_list<slot_type> slot_list_type;
typedef typename slot_list_type::iterator iterator;
typedef typename slot_list_type::const_iterator const_iterator;
@@ -101,21 +101,20 @@ public:
* a blocking state. The parameters are passed on to the slots.
* If @e T_accumulated is not @p nil, an accumulator of this type
* is used to process the return values of the slot invocations.
- * Otherwise, the return value of the last slot invoked is returned.dnl
-FOR(1, $1,[
- * @param _A_a%1 Argument to be passed on to the slots.])
+ * Otherwise, the return value of the last slot invoked is returned.
+ * @param _A_a Arguments to be passed on to the slots.
* @return The accumulated return values of the slot invocations.
*/
- result_type emit(LOOP(type_trait_take_t<T_arg%1> _A_a%1, $1)) const
- { return emitter_type::emit(LIST(impl_, LOOP(_A_a%1, $1))); }
+ result_type emit(type_trait_take_t<T_arg>... _A_a) const
+ { return emitter_type::emit(impl_, _A_a...); }
/** Triggers the emission of the signal in reverse order (see emit()). */
- result_type emit_reverse(LOOP(type_trait_take_t<T_arg%1> _A_a%1, $1)) const
- { return emitter_type::emit_reverse(LIST(impl_, LOOP(_A_a%1, $1))); }
+ result_type emit_reverse(type_trait_take_t<T_arg>... _A_a) const
+ { return emitter_type::emit_reverse(impl_, _A_a...); }
/** Triggers the emission of the signal (see emit()). */
- result_type operator()(LOOP(type_trait_take_t<T_arg%1> _A_a%1, $1)) const
- { return emit(LOOP(_A_a%1, $1)); }
+ result_type operator()(type_trait_take_t<T_arg>... _A_a) const
+ { return emit(_A_a...); }
/** Creates a functor that calls emit() on this signal.
* @code
@@ -124,8 +123,8 @@ FOR(1, $1,[
* yields the same result.
* @return A functor that calls emit() on this signal.
*/
- bound_const_mem_functor<LIST(result_type, signal$1, LOOP(type_trait_take_t<T_arg%1>, $1))> make_slot()
const
- { return bound_const_mem_functor<LIST(result_type, signal$1, LOOP(type_trait_take_t<T_arg%1>,
$1))>(this, &signal$1::emit); }
+ bound_const_mem_functor<result_type, signal$1, type_trait_take_t<T_arg>...> make_slot() const
+ { return bound_const_mem_functor<result_type, signal$1, type_trait_take_t<T_arg>...>(this,
&signal$1::emit); }
/** Creates an STL-style interface for the signal's list of slots.
* This interface supports iteration, insertion and removal of slots.
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]