Chromium Code Reviews| Index: media/base/bind_to_loop.h |
| diff --git a/media/base/bind_to_loop.h b/media/base/bind_to_loop.h |
| index 24f941968f8005c08a6d791f3cc961018e46d246..ad21e22550f839e716113faef46fb9a84da514c6 100644 |
| --- a/media/base/bind_to_loop.h |
| +++ b/media/base/bind_to_loop.h |
| @@ -11,7 +11,6 @@ |
| #define MEDIA_BASE_BIND_TO_LOOP_H_ |
| #include "base/bind.h" |
| -#include "base/callback_internal.h" // Avoid re-inventing CallbackForward. |
| #include "base/location.h" |
| #include "base/message_loop_proxy.h" |
| @@ -31,6 +30,29 @@ |
| namespace media { |
| +// Mimic base::internal::CallbackForward, replacing p.Pass() with |
| +// base::Passed(&p) to account for the extra layer of indirection. |
| +namespace internal { |
| +template <typename T> |
| +T& TrampolineForward(T& t) { return t; } |
|
awong
2012/10/11 00:18:22
Crazy idea...can we do anything really trick with
Ami GONE FROM CHROMIUM
2012/10/11 07:20:39
Played with this for a while and failed at it (and
|
| + |
| +template <typename T> |
| +base::internal::PassedWrapper<scoped_ptr<T> > TrampolineForward( |
| + scoped_ptr<T>& p) { return base::Passed(&p); } |
| + |
| +template <typename T> |
| +base::internal::PassedWrapper<scoped_array<T> > TrampolineForward( |
| + scoped_array<T>& p) { return base::Passed(&p); } |
| + |
| +template <typename T, typename R> |
| +base::internal::PassedWrapper<scoped_ptr_malloc<T, R> > TrampolineForward( |
| + scoped_ptr_malloc<T, R>& p) { base::Passed(&p); } |
| + |
| +template <typename T> |
| +base::internal::PassedWrapper<ScopedVector<T> > TrampolineForward( |
| + ScopedVector<T>& p) { return base::Passed(&p); } |
| +} |
| + |
| template <typename T> struct TrampolineHelper; |
| template <> |
| @@ -48,8 +70,7 @@ struct TrampolineHelper<void(A1)> { |
| static void Run( |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1)>& cb, A1 a1) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1))); |
| } |
| }; |
| @@ -59,9 +80,8 @@ struct TrampolineHelper<void(A1, A2)> { |
| static void Run( |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1, A2)>& cb, A1 a1, A2 a2) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1), |
| - base::internal::CallbackForward(a2))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1), |
| + internal::TrampolineForward(a2))); |
| } |
| }; |
| @@ -71,10 +91,8 @@ struct TrampolineHelper<void(A1, A2, A3)> { |
| static void Run( |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1, A2, A3)>& cb, A1 a1, A2 a2, A3 a3) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1), |
| - base::internal::CallbackForward(a2), |
| - base::internal::CallbackForward(a3))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1), |
| + internal::TrampolineForward(a2), internal::TrampolineForward(a3))); |
| } |
| }; |
| @@ -85,11 +103,9 @@ struct TrampolineHelper<void(A1, A2, A3, A4)> { |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1, A2, A3, A4)>& cb, A1 a1, A2 a2, A3 a3, |
| A4 a4) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1), |
| - base::internal::CallbackForward(a2), |
| - base::internal::CallbackForward(a3), |
| - base::internal::CallbackForward(a4))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1), |
| + internal::TrampolineForward(a2), internal::TrampolineForward(a3), |
| + internal::TrampolineForward(a4))); |
| } |
| }; |
| @@ -100,12 +116,9 @@ struct TrampolineHelper<void(A1, A2, A3, A4, A5)> { |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1, A2, A3, A4, A5)>& cb, A1 a1, A2 a2, A3 a3, |
| A4 a4, A5 a5) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1), |
| - base::internal::CallbackForward(a2), |
| - base::internal::CallbackForward(a3), |
| - base::internal::CallbackForward(a4), |
| - base::internal::CallbackForward(a5))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1), |
| + internal::TrampolineForward(a2), internal::TrampolineForward(a3), |
| + internal::TrampolineForward(a4), internal::TrampolineForward(a5))); |
| } |
| }; |
| @@ -117,13 +130,10 @@ struct TrampolineHelper<void(A1, A2, A3, A4, A5, A6)> { |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1, A2, A3, A4, A5, A6)>& cb, A1 a1, A2 a2, |
| A3 a3, A4 a4, A5 a5, A6 a6) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1), |
| - base::internal::CallbackForward(a2), |
| - base::internal::CallbackForward(a3), |
| - base::internal::CallbackForward(a4), |
| - base::internal::CallbackForward(a5), |
| - base::internal::CallbackForward(a6))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1), |
| + internal::TrampolineForward(a2), internal::TrampolineForward(a3), |
| + internal::TrampolineForward(a4), internal::TrampolineForward(a5), |
| + internal::TrampolineForward(a6))); |
| } |
| }; |
| @@ -135,14 +145,10 @@ struct TrampolineHelper<void(A1, A2, A3, A4, A5, A6, A7)> { |
| const scoped_refptr<base::MessageLoopProxy>& loop, |
| const base::Callback<void(A1, A2, A3, A4, A5, A6, A7)>& cb, A1 a1, A2 a2, |
| A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) { |
| - loop->PostTask(FROM_HERE, base::Bind(cb, |
| - base::internal::CallbackForward(a1), |
| - base::internal::CallbackForward(a2), |
| - base::internal::CallbackForward(a3), |
| - base::internal::CallbackForward(a4), |
| - base::internal::CallbackForward(a5), |
| - base::internal::CallbackForward(a6), |
| - base::internal::CallbackForward(a7))); |
| + loop->PostTask(FROM_HERE, base::Bind(cb, internal::TrampolineForward(a1), |
| + internal::TrampolineForward(a2), internal::TrampolineForward(a3), |
| + internal::TrampolineForward(a4), internal::TrampolineForward(a5), |
| + internal::TrampolineForward(a6), internal::TrampolineForward(a7))); |
| } |
| }; |