| Index: media/base/bind_to_loop.h.pump
|
| diff --git a/media/base/bind_to_loop.h.pump b/media/base/bind_to_loop.h.pump
|
| index a2b48bf0d19d79dacef40ab5ebccaec7efb1c34f..42d2467dbc3f7ee8a305ef1d34b37db9fae26d18 100644
|
| --- a/media/base/bind_to_loop.h.pump
|
| +++ b/media/base/bind_to_loop.h.pump
|
| @@ -16,7 +16,6 @@ $var MAX_ARITY = 7
|
| #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"
|
|
|
| @@ -36,6 +35,29 @@ $var MAX_ARITY = 7
|
|
|
| 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; }
|
| +
|
| +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;
|
|
|
| $range ARITY 0..MAX_ARITY
|
| @@ -52,7 +74,7 @@ $for ARG , [[A$(ARG) a$(ARG)]]
|
| ) {
|
| loop->PostTask(FROM_HERE, base::Bind(cb
|
| $if ARITY != 0 [[, ]]
|
| -$for ARG , [[base::internal::CallbackForward(a$(ARG))]]));
|
| +$for ARG , [[internal::TrampolineForward(a$(ARG))]]));
|
| }
|
| };
|
|
|
|
|