Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(836)

Unified Diff: media/base/bind_to_loop.h.pump

Issue 11092054: Teach BindToLoop to create callbacks that accept scoped parameters. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Another applicable site Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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..87c383e69e553c382a45fc624ff062dd2c05557e 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,28 @@ $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,18 +73,20 @@ $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))]]));
}
};
xhwang 2012/10/23 21:37:03 Did you put two empty lines here on purpose?
Ami GONE FROM CHROMIUM 2012/10/23 21:58:07 Mimicing the callback pump file. I don't think it
]] $$ for ARITY
+} // namespace internal
+
template<typename T>
static base::Callback<T> BindToLoop(
const scoped_refptr<base::MessageLoopProxy>& loop,
const base::Callback<T>& cb) {
- return base::Bind(&TrampolineHelper<T>::Run, loop, cb);
+ return base::Bind(&internal::TrampolineHelper<T>::Run, loop, cb);
}
} // namespace media

Powered by Google App Engine
This is Rietveld 408576698