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

Unified Diff: chrome/browser/sync/glue/history_model_worker.cc

Issue 8366030: Introduce the plumbing necessary to report Unrecoverable error from model safe workers. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: For try jobs. Created 9 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
« no previous file with comments | « chrome/browser/sync/glue/history_model_worker.h ('k') | chrome/browser/sync/glue/password_model_worker.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/sync/glue/history_model_worker.cc
diff --git a/chrome/browser/sync/glue/history_model_worker.cc b/chrome/browser/sync/glue/history_model_worker.cc
index 5ad866431cccab9db5b76624a9b2390697b2506a..84200ac2c320e6d56f5836daebc8eaec38c761da 100644
--- a/chrome/browser/sync/glue/history_model_worker.cc
+++ b/chrome/browser/sync/glue/history_model_worker.cc
@@ -16,12 +16,15 @@ namespace browser_sync {
class WorkerTask : public HistoryDBTask {
public:
- WorkerTask(Callback0::Type* work, WaitableEvent* done)
- : work_(work), done_(done) {}
+ WorkerTask(
+ const WorkCallback& work,
+ WaitableEvent* done,
+ UnrecoverableErrorInfo* error_info)
+ : work_(work), done_(done), error_info_(error_info) {}
virtual bool RunOnDBThread(history::HistoryBackend* backend,
history::HistoryDatabase* db) {
- work_->Run();
+ *error_info_ = work_.Run();
done_->Signal();
return true;
}
@@ -31,8 +34,9 @@ class WorkerTask : public HistoryDBTask {
virtual void DoneRunOnMainThread() {}
protected:
- Callback0::Type* work_;
+ WorkCallback work_;
WaitableEvent* done_;
+ UnrecoverableErrorInfo* error_info_;
};
@@ -44,11 +48,14 @@ HistoryModelWorker::HistoryModelWorker(HistoryService* history_service)
HistoryModelWorker::~HistoryModelWorker() {
}
-void HistoryModelWorker::DoWorkAndWaitUntilDone(Callback0::Type* work) {
+UnrecoverableErrorInfo HistoryModelWorker::DoWorkAndWaitUntilDone(
+ const WorkCallback& work) {
WaitableEvent done(false, false);
- scoped_refptr<WorkerTask> task(new WorkerTask(work, &done));
+ UnrecoverableErrorInfo error_info;
+ scoped_refptr<WorkerTask> task(new WorkerTask(work, &done, &error_info));
history_service_->ScheduleDBTask(task.get(), &cancelable_consumer_);
done.Wait();
+ return error_info;
}
ModelSafeGroup HistoryModelWorker::GetModelSafeGroup() {
« no previous file with comments | « chrome/browser/sync/glue/history_model_worker.h ('k') | chrome/browser/sync/glue/password_model_worker.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698