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

Unified Diff: chrome/browser/sync_file_system/drive_backend/callback_helper.h

Issue 304153007: [SyncFS][Reland] Relay callback destruction to TaskRunner on RelayCallbackToTaskRunner (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: wrap .h.pump to 80 chars Created 6 years, 7 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
« no previous file with comments | « no previous file | chrome/browser/sync_file_system/drive_backend/callback_helper.h.pump » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/sync_file_system/drive_backend/callback_helper.h
diff --git a/chrome/browser/sync_file_system/drive_backend/callback_helper.h b/chrome/browser/sync_file_system/drive_backend/callback_helper.h
index f48b12268700b19826cc694d168873ccdb1d236b..ba01b67691f42f02e9ae2e893abbbc1067fbe0f6 100644
--- a/chrome/browser/sync_file_system/drive_backend/callback_helper.h
+++ b/chrome/browser/sync_file_system/drive_backend/callback_helper.h
@@ -13,6 +13,7 @@
#include "base/bind.h"
#include "base/location.h"
#include "base/logging.h"
+#include "base/sequenced_task_runner.h"
#include "base/thread_task_runner_handle.h"
// TODO(tzik): Merge this file to media/base/bind_to_current_loop.h.
@@ -38,95 +39,116 @@ RebindForward(T& t) {
return t;
}
+template <typename T>
+class CallbackHolder {
+ public:
+ CallbackHolder(base::SequencedTaskRunner* task_runner,
+ const tracked_objects::Location& from_here,
+ const base::Callback<T>& callback)
+ : task_runner_(task_runner),
+ from_here_(from_here),
+ callback_(new base::Callback<T>(callback)) {
+ DCHECK(task_runner_);
+ }
+
+ ~CallbackHolder() {
+ base::Callback<T>* callback = callback_.release();
+ if (!task_runner_->DeleteSoon(from_here_, callback))
+ delete callback;
+ }
+
+ base::SequencedTaskRunner* task_runner() const { return task_runner_; }
+ const tracked_objects::Location& from_here() const { return from_here_; }
+ const base::Callback<T>& callback() const { return *callback_; }
+
+ private:
+ scoped_refptr<base::SequencedTaskRunner> task_runner_;
+ const tracked_objects::Location from_here_;
+ scoped_ptr<base::Callback<T> > callback_;
+
+ DISALLOW_COPY_AND_ASSIGN(CallbackHolder);
+};
+
template <typename>
struct RelayToTaskRunnerHelper;
template <>
struct RelayToTaskRunnerHelper<void()> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void()>& callback) {
- task_runner->PostTask(from_here, base::Bind(callback));
+ static void Run(CallbackHolder<void()>* holder) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback()));
}
};
template <typename A1>
struct RelayToTaskRunnerHelper<void(A1)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1)>& callback, A1 a1) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1)));
+ static void Run(CallbackHolder<void(A1)>* holder, A1 a1) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1)));
}
};
template <typename A1, typename A2>
struct RelayToTaskRunnerHelper<void(A1, A2)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1, A2)>& callback, A1 a1, A2 a2) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1),
- RebindForward(a2)));
+ static void Run(CallbackHolder<void(A1, A2)>* holder, A1 a1, A2 a2) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1),
+ RebindForward(a2)));
}
};
template <typename A1, typename A2, typename A3>
struct RelayToTaskRunnerHelper<void(A1, A2, A3)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1, A2, A3)>& callback, A1 a1,
- A2 a2, A3 a3) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1),
- RebindForward(a2), RebindForward(a3)));
+ static void Run(CallbackHolder<void(A1, A2, A3)>* holder, A1 a1, A2 a2,
+ A3 a3) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1),
+ RebindForward(a2), RebindForward(a3)));
}
};
template <typename A1, typename A2, typename A3, typename A4>
struct RelayToTaskRunnerHelper<void(A1, A2, A3, A4)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1, A2, A3, A4)>& callback, A1 a1,
- A2 a2, A3 a3, A4 a4) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1),
- RebindForward(a2), RebindForward(a3), RebindForward(a4)));
+ static void Run(CallbackHolder<void(A1, A2, A3, A4)>* holder, A1 a1, A2 a2,
+ A3 a3, A4 a4) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1),
+ RebindForward(a2), RebindForward(a3), RebindForward(a4)));
}
};
template <typename A1, typename A2, typename A3, typename A4, typename A5>
struct RelayToTaskRunnerHelper<void(A1, A2, A3, A4, A5)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1, A2, A3, A4, A5)>& callback,
- A1 a1, A2 a2, A3 a3, A4 a4, A5 a5) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1),
- RebindForward(a2), RebindForward(a3), RebindForward(a4),
- RebindForward(a5)));
+ static void Run(CallbackHolder<void(A1, A2, A3, A4, A5)>* holder, A1 a1,
+ A2 a2, A3 a3, A4 a4, A5 a5) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1),
+ RebindForward(a2), RebindForward(a3), RebindForward(a4),
+ RebindForward(a5)));
}
};
template <typename A1, typename A2, typename A3, typename A4, typename A5,
typename A6>
struct RelayToTaskRunnerHelper<void(A1, A2, A3, A4, A5, A6)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1, A2, A3, A4, A5, A6)>& callback,
- A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1),
- RebindForward(a2), RebindForward(a3), RebindForward(a4),
- RebindForward(a5), RebindForward(a6)));
+ static void Run(CallbackHolder<void(A1, A2, A3, A4, A5, A6)>* holder, A1 a1,
+ A2 a2, A3 a3, A4 a4, A5 a5, A6 a6) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1),
+ RebindForward(a2), RebindForward(a3), RebindForward(a4),
+ RebindForward(a5), RebindForward(a6)));
}
};
template <typename A1, typename A2, typename A3, typename A4, typename A5,
typename A6, typename A7>
struct RelayToTaskRunnerHelper<void(A1, A2, A3, A4, A5, A6, A7)> {
- static void Run(base::TaskRunner* task_runner,
- const tracked_objects::Location& from_here,
- const base::Callback<void(A1, A2, A3, A4, A5, A6,
- A7)>& callback, A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6,
- A7 a7) {
- task_runner->PostTask(from_here, base::Bind(callback, RebindForward(a1),
- RebindForward(a2), RebindForward(a3), RebindForward(a4),
- RebindForward(a5), RebindForward(a6), RebindForward(a7)));
+ static void Run(CallbackHolder<void(A1, A2, A3, A4, A5, A6, A7)>* holder,
+ A1 a1, A2 a2, A3 a3, A4 a4, A5 a5, A6 a6, A7 a7) {
+ holder->task_runner()->PostTask(
+ holder->from_here(), base::Bind(holder->callback(), RebindForward(a1),
+ RebindForward(a2), RebindForward(a3), RebindForward(a4),
+ RebindForward(a5), RebindForward(a6), RebindForward(a7)));
}
};
@@ -134,7 +156,7 @@ struct RelayToTaskRunnerHelper<void(A1, A2, A3, A4, A5, A6, A7)> {
template <typename T>
base::Callback<T> RelayCallbackToTaskRunner(
- base::TaskRunner* task_runner,
+ base::SequencedTaskRunner* task_runner,
const tracked_objects::Location& from_here,
const base::Callback<T>& callback) {
DCHECK(task_runner->RunsTasksOnCurrentThread());
@@ -143,8 +165,8 @@ base::Callback<T> RelayCallbackToTaskRunner(
return base::Callback<T>();
return base::Bind(&internal::RelayToTaskRunnerHelper<T>::Run,
- make_scoped_refptr(task_runner), from_here,
- callback);
+ base::Owned(new internal::CallbackHolder<T>(
+ task_runner, from_here, callback)));
}
template <typename T>
« no previous file with comments | « no previous file | chrome/browser/sync_file_system/drive_backend/callback_helper.h.pump » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698