57 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
| /*
 | |
|  *  Copyright 2017 The WebRTC Project Authors. All rights reserved.
 | |
|  *
 | |
|  *  Use of this source code is governed by a BSD-style license
 | |
|  *  that can be found in the LICENSE file in the root of the source
 | |
|  *  tree. An additional intellectual property rights grant can be found
 | |
|  *  in the file PATENTS.  All contributing project authors may
 | |
|  *  be found in the AUTHORS file in the root of the source tree.
 | |
|  */
 | |
| 
 | |
| #ifndef RTC_BASE_SIGSLOT_REPEATER_H__
 | |
| #define RTC_BASE_SIGSLOT_REPEATER_H__
 | |
| 
 | |
| // repeaters are both signals and slots, which are designed as intermediate
 | |
| // pass-throughs for signals and slots which don't know about each other (for
 | |
| // modularity or encapsulation).  This eliminates the need to declare a signal
 | |
| // handler whose sole purpose is to fire another signal.  The repeater connects
 | |
| // to the originating signal using the 'repeat' method.  When the repeated
 | |
| // signal fires, the repeater will also fire.
 | |
| //
 | |
| // TODO(deadbeef): Actually use this, after we decide on some style points on
 | |
| // using signals, so it doesn't get deleted again.
 | |
| 
 | |
| #include "rtc_base/third_party/sigslot/sigslot.h"
 | |
| 
 | |
| namespace sigslot {
 | |
| 
 | |
| template <class mt_policy, typename... Args>
 | |
| class repeater_with_thread_policy
 | |
|     : public signal_with_thread_policy<mt_policy, Args...>,
 | |
|       public has_slots<mt_policy> {
 | |
|  private:
 | |
|   // These typedefs are just to make the code below more readable. Code using
 | |
|   // repeaters shouldn't need to reference these types directly.
 | |
|   typedef signal_with_thread_policy<mt_policy, Args...> base_type;
 | |
|   typedef repeater_with_thread_policy<mt_policy, Args...> this_type;
 | |
| 
 | |
|  public:
 | |
|   repeater_with_thread_policy() {}
 | |
|   repeater_with_thread_policy(const this_type& s) : base_type(s) {}
 | |
| 
 | |
|   void reemit(Args... args) { base_type::emit(args...); }
 | |
|   void repeat(base_type& s) { s.connect(this, &this_type::reemit); }
 | |
|   void stop(base_type& s) { s.disconnect(this); }
 | |
| };
 | |
| 
 | |
| // Alias with default thread policy. Needed because both default arguments
 | |
| // and variadic template arguments must go at the end of the list, so we
 | |
| // can't have both at once.
 | |
| template <typename... Args>
 | |
| using repeater =
 | |
|     repeater_with_thread_policy<SIGSLOT_DEFAULT_MT_POLICY, Args...>;
 | |
| 
 | |
| }  // namespace sigslot
 | |
| 
 | |
| #endif  // RTC_BASE_SIGSLOT_REPEATER_H__
 |