Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 $$ This is a pump file for generating file templates. Pump is a python | 1 $$ This is a pump file for generating file templates. Pump is a python |
| 2 $$ script that is part of the Google Test suite of utilities. Description | 2 $$ script that is part of the Google Test suite of utilities. Description |
| 3 $$ can be found here: | 3 $$ can be found here: |
| 4 $$ | 4 $$ |
| 5 $$ http://code.google.com/p/googletest/wiki/PumpManual | 5 $$ http://code.google.com/p/googletest/wiki/PumpManual |
| 6 $$ | 6 $$ |
| 7 | 7 |
| 8 $$ See comment for MAX_ARITY in base/bind.h.pump. | 8 $$ See comment for MAX_ARITY in base/bind.h.pump. |
| 9 $var MAX_ARITY = 7 | 9 $var MAX_ARITY = 7 |
| 10 | 10 |
| 11 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 11 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 12 // Use of this source code is governed by a BSD-style license that can be | 12 // Use of this source code is governed by a BSD-style license that can be |
| 13 // found in the LICENSE file. | 13 // found in the LICENSE file. |
| 14 | 14 |
| 15 #ifndef MEDIA_BASE_BIND_TO_LOOP_H_ | 15 #ifndef MEDIA_BASE_BIND_TO_LOOP_H_ |
| 16 #define MEDIA_BASE_BIND_TO_LOOP_H_ | 16 #define MEDIA_BASE_BIND_TO_LOOP_H_ |
| 17 | 17 |
| 18 #include "base/bind.h" | 18 #include "base/bind.h" |
| 19 #include "base/location.h" | 19 #include "base/location.h" |
| 20 #include "base/message_loop/message_loop_proxy.h" | 20 #include "base/message_loop/message_loop_proxy.h" |
| 21 #include "base/single_thread_task_runner.h" | |
| 21 | 22 |
| 22 // This is a helper utility for base::Bind()ing callbacks on to particular | 23 // This is a helper utility for base::Bind()ing callbacks on to particular |
| 23 // MessageLoops. A typical use is when |a| (of class |A|) wants to hand a | 24 // MessageLoops. A typical use is when |a| (of class |A|) wants to hand a |
| 24 // callback such as base::Bind(&A::AMethod, a) to |b|, but needs to ensure that | 25 // callback such as base::Bind(&A::AMethod, a) to |b|, but needs to ensure that |
| 25 // when |b| executes the callback, it does so on a particular MessageLoop. | 26 // when |b| executes the callback, it does so on a particular MessageLoop. |
| 26 // | 27 // |
| 27 // Typical usage: request to be called back on the current thread: | 28 // Typical usage: request to be called back on the current thread: |
| 28 // other->StartAsyncProcessAndCallMeBack( | 29 // other->StartAsyncProcessAndCallMeBack( |
| 29 // media::BindToLoop(MessageLoopProxy::current(), | 30 // media::BindToLoop(MessageLoopProxy::current(), |
| 30 // base::Bind(&MyClass::MyMethod, this))); | 31 // base::Bind(&MyClass::MyMethod, this))); |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 55 | 56 |
| 56 template <typename T> struct TrampolineHelper; | 57 template <typename T> struct TrampolineHelper; |
| 57 | 58 |
| 58 $range ARITY 0..MAX_ARITY | 59 $range ARITY 0..MAX_ARITY |
| 59 $for ARITY [[ | 60 $for ARITY [[ |
| 60 $range ARG 1..ARITY | 61 $range ARG 1..ARITY |
| 61 | 62 |
| 62 template <$for ARG , [[typename A$(ARG)]]> | 63 template <$for ARG , [[typename A$(ARG)]]> |
| 63 struct TrampolineHelper<void($for ARG , [[A$(ARG)]])> { | 64 struct TrampolineHelper<void($for ARG , [[A$(ARG)]])> { |
| 64 static void Run( | 65 static void Run( |
| 65 const scoped_refptr<base::MessageLoopProxy>& loop, | 66 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, |
| 66 const base::Callback<void($for ARG , [[A$(ARG)]])>& cb | 67 const base::Callback<void($for ARG , [[A$(ARG)]])>& cb |
| 67 $if ARITY != 0 [[, ]] | 68 $if ARITY != 0 [[, ]] |
| 68 $for ARG , [[A$(ARG) a$(ARG)]] | 69 $for ARG , [[A$(ARG) a$(ARG)]] |
| 69 ) { | 70 ) { |
| 70 loop->PostTask(FROM_HERE, base::Bind(cb | 71 task_runner->PostTask(FROM_HERE, base::Bind(cb |
| 71 $if ARITY != 0 [[, ]] | 72 $if ARITY != 0 [[, ]] |
| 72 $for ARG , [[internal::TrampolineForward(a$(ARG))]])); | 73 $for ARG , [[internal::TrampolineForward(a$(ARG))]])); |
| 73 } | 74 } |
| 74 }; | 75 }; |
| 75 | 76 |
| 76 | 77 |
| 77 ]] $$ for ARITY | 78 ]] $$ for ARITY |
| 78 | 79 |
| 79 } // namespace internal | 80 } // namespace internal |
| 80 | 81 |
| 81 template<typename T> | 82 template<typename T> |
| 82 static base::Callback<T> BindToLoop( | 83 static base::Callback<T> BindToLoop( |
|
Ami GONE FROM CHROMIUM
2013/11/08 16:54:46
Mellifluous though "BindToLoop" is, it's now a bit
scherkus (not reviewing)
2013/11/08 21:51:39
I think it's still fair to pass in a STTR.
As dis
| |
| 83 const scoped_refptr<base::MessageLoopProxy>& loop, | 84 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, |
| 84 const base::Callback<T>& cb) { | 85 const base::Callback<T>& cb) { |
| 85 return base::Bind(&internal::TrampolineHelper<T>::Run, loop, cb); | 86 return base::Bind(&internal::TrampolineHelper<T>::Run, task_runner, cb); |
| 86 } | 87 } |
| 87 | 88 |
| 88 template<typename T> | 89 template<typename T> |
| 89 static base::Callback<T> BindToCurrentLoop( | 90 static base::Callback<T> BindToCurrentLoop( |
| 90 const base::Callback<T>& cb) { | 91 const base::Callback<T>& cb) { |
| 91 return BindToLoop(base::MessageLoopProxy::current(), cb); | 92 return BindToLoop(base::MessageLoopProxy::current(), cb); |
| 92 } | 93 } |
| 93 | 94 |
| 94 } // namespace media | 95 } // namespace media |
| 95 | 96 |
| 96 #endif // MEDIA_BASE_BIND_TO_LOOP_H_ | 97 #endif // MEDIA_BASE_BIND_TO_LOOP_H_ |
| OLD | NEW |