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

Side by Side Diff: components/sync/driver/glue/browser_thread_model_worker.cc

Issue 2503423004: [Sync] Move sync's ModelSafeWorker implementations to engine/. (Closed)
Patch Set: Rebase. Created 4 years, 1 month 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "components/sync/driver/glue/browser_thread_model_worker.h"
6
7 #include "base/bind.h"
8 #include "base/callback.h"
9 #include "base/single_thread_task_runner.h"
10 #include "base/synchronization/waitable_event.h"
11
12 using base::SingleThreadTaskRunner;
13
14 namespace syncer {
15
16 BrowserThreadModelWorker::BrowserThreadModelWorker(
17 const scoped_refptr<SingleThreadTaskRunner>& runner,
18 ModelSafeGroup group)
19 : runner_(runner), group_(group) {}
20
21 SyncerError BrowserThreadModelWorker::DoWorkAndWaitUntilDoneImpl(
22 const WorkCallback& work) {
23 SyncerError error = UNSET;
24 if (runner_->BelongsToCurrentThread()) {
25 DLOG(WARNING) << "Already on thread " << runner_;
26 return work.Run();
27 }
28
29 // Signaled when the task is deleted, i.e. after it runs or when it is
30 // abandoned.
31 base::WaitableEvent work_done_or_abandoned(
32 base::WaitableEvent::ResetPolicy::AUTOMATIC,
33 base::WaitableEvent::InitialState::NOT_SIGNALED);
34
35 if (!runner_->PostTask(
36 FROM_HERE,
37 base::Bind(
38 &BrowserThreadModelWorker::CallDoWorkAndSignalTask, this, work,
39 base::Passed(syncer::ScopedEventSignal(&work_done_or_abandoned)),
40 &error))) {
41 DLOG(WARNING) << "Failed to post task to runner " << runner_;
42 error = CANNOT_DO_WORK;
43 return error;
44 }
45 work_done_or_abandoned.Wait();
46 return error;
47 }
48
49 ModelSafeGroup BrowserThreadModelWorker::GetModelSafeGroup() {
50 return group_;
51 }
52
53 bool BrowserThreadModelWorker::IsOnModelThread() {
54 return runner_->BelongsToCurrentThread();
55 }
56
57 BrowserThreadModelWorker::~BrowserThreadModelWorker() {}
58
59 void BrowserThreadModelWorker::CallDoWorkAndSignalTask(
60 const WorkCallback& work,
61 syncer::ScopedEventSignal scoped_event_signal,
62 SyncerError* error) {
63 DCHECK(runner_->BelongsToCurrentThread());
64 if (!IsStopped())
65 *error = work.Run();
66 // The event in |scoped_event_signal| is signaled at the end of this scope.
67 }
68
69 } // namespace syncer
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698