1 /*
2  *  Copyright 2006 The WebRTC Project Authors. All rights reserved.
3  *
4  *  Use of this source code is governed by a BSD-style license
5  *  that can be found in the LICENSE file in the root of the source
6  *  tree. An additional intellectual property rights grant can be found
7  *  in the file PATENTS.  All contributing project authors may
8  *  be found in the AUTHORS file in the root of the source tree.
9  */
10 
11 #ifndef WEBRTC_BASE_SIGSLOTREPEATER_H__
12 #define WEBRTC_BASE_SIGSLOTREPEATER_H__
13 
14 // repeaters are both signals and slots, which are designed as intermediate
15 // pass-throughs for signals and slots which don't know about each other (for
16 // modularity or encapsulation).  This eliminates the need to declare a signal
17 // handler whose sole purpose is to fire another signal.  The repeater connects
18 // to the originating signal using the 'repeat' method.  When the repeated
19 // signal fires, the repeater will also fire.
20 
21 #include "webrtc/base/sigslot.h"
22 
23 namespace sigslot {
24 
25   template<class mt_policy = SIGSLOT_DEFAULT_MT_POLICY>
26   class repeater0 : public signal0<mt_policy>,
27                     public has_slots<mt_policy>
28   {
29   public:
30     typedef signal0<mt_policy> base_type;
31     typedef repeater0<mt_policy> this_type;
32 
repeater0()33     repeater0() { }
repeater0(const this_type & s)34     repeater0(const this_type& s) : base_type(s) { }
35 
reemit()36     void reemit() { signal0<mt_policy>::emit(); }
repeat(base_type & s)37     void repeat(base_type &s) { s.connect(this, &this_type::reemit); }
stop(base_type & s)38     void stop(base_type &s) { s.disconnect(this); }
39   };
40 
41   template<class arg1_type, class mt_policy = SIGSLOT_DEFAULT_MT_POLICY>
42   class repeater1 : public signal1<arg1_type, mt_policy>,
43                     public has_slots<mt_policy>
44   {
45   public:
46     typedef signal1<arg1_type, mt_policy> base_type;
47     typedef repeater1<arg1_type, mt_policy> this_type;
48 
repeater1()49     repeater1() { }
repeater1(const this_type & s)50     repeater1(const this_type& s) : base_type(s) { }
51 
reemit(arg1_type a1)52     void reemit(arg1_type a1) { signal1<arg1_type, mt_policy>::emit(a1); }
repeat(base_type & s)53     void repeat(base_type& s) { s.connect(this, &this_type::reemit); }
stop(base_type & s)54     void stop(base_type &s) { s.disconnect(this); }
55   };
56 
57   template<class arg1_type, class arg2_type, class mt_policy = SIGSLOT_DEFAULT_MT_POLICY>
58   class repeater2 : public signal2<arg1_type, arg2_type, mt_policy>,
59                     public has_slots<mt_policy>
60   {
61   public:
62     typedef signal2<arg1_type, arg2_type, mt_policy> base_type;
63     typedef repeater2<arg1_type, arg2_type, mt_policy> this_type;
64 
repeater2()65     repeater2() { }
repeater2(const this_type & s)66     repeater2(const this_type& s) : base_type(s) { }
67 
reemit(arg1_type a1,arg2_type a2)68     void reemit(arg1_type a1, arg2_type a2) { signal2<arg1_type, arg2_type, mt_policy>::emit(a1,a2); }
repeat(base_type & s)69     void repeat(base_type& s) { s.connect(this, &this_type::reemit); }
stop(base_type & s)70     void stop(base_type &s) { s.disconnect(this); }
71   };
72 
73   template<class arg1_type, class arg2_type, class arg3_type,
74            class mt_policy = SIGSLOT_DEFAULT_MT_POLICY>
75   class repeater3 : public signal3<arg1_type, arg2_type, arg3_type, mt_policy>,
76                     public has_slots<mt_policy>
77   {
78   public:
79     typedef signal3<arg1_type, arg2_type, arg3_type, mt_policy> base_type;
80     typedef repeater3<arg1_type, arg2_type, arg3_type, mt_policy> this_type;
81 
repeater3()82     repeater3() { }
repeater3(const this_type & s)83     repeater3(const this_type& s) : base_type(s) { }
84 
reemit(arg1_type a1,arg2_type a2,arg3_type a3)85     void reemit(arg1_type a1, arg2_type a2, arg3_type a3) {
86             signal3<arg1_type, arg2_type, arg3_type, mt_policy>::emit(a1,a2,a3);
87     }
repeat(base_type & s)88     void repeat(base_type& s) { s.connect(this, &this_type::reemit); }
stop(base_type & s)89     void stop(base_type &s) { s.disconnect(this); }
90   };
91 
92 }  // namespace sigslot
93 
94 #endif  // WEBRTC_BASE_SIGSLOTREPEATER_H__
95