OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/sync/glue/password_model_worker.h" | 5 #include "chrome/browser/sync/glue/password_model_worker.h" |
6 | 6 |
7 #include "base/callback.h" | 7 #include "base/callback.h" |
8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
9 #include "base/task.h" | 9 #include "base/task.h" |
10 #include "base/synchronization/waitable_event.h" | 10 #include "base/synchronization/waitable_event.h" |
11 #include "chrome/browser/password_manager/password_store.h" | 11 #include "chrome/browser/password_manager/password_store.h" |
12 | 12 |
13 using base::WaitableEvent; | 13 using base::WaitableEvent; |
14 | 14 |
15 namespace browser_sync { | 15 namespace browser_sync { |
| 16 using sessions::UnrecoverableErrorInfo; |
16 | 17 |
17 PasswordModelWorker::PasswordModelWorker(PasswordStore* password_store) | 18 PasswordModelWorker::PasswordModelWorker(PasswordStore* password_store) |
18 : password_store_(password_store) { | 19 : password_store_(password_store) { |
19 DCHECK(password_store); | 20 DCHECK(password_store); |
20 } | 21 } |
21 | 22 |
22 PasswordModelWorker::~PasswordModelWorker() {} | 23 PasswordModelWorker::~PasswordModelWorker() {} |
23 | 24 |
24 void PasswordModelWorker::DoWorkAndWaitUntilDone(Callback0::Type* work) { | 25 UnrecoverableErrorInfo PasswordModelWorker::DoWorkAndWaitUntilDone( |
| 26 Callback1<sessions::UnrecoverableErrorInfo*>::Type* work) { |
25 WaitableEvent done(false, false); | 27 WaitableEvent done(false, false); |
| 28 UnrecoverableErrorInfo error_info; |
26 password_store_->ScheduleTask( | 29 password_store_->ScheduleTask( |
27 NewRunnableMethod(this, &PasswordModelWorker::CallDoWorkAndSignalTask, | 30 NewRunnableMethod(this, &PasswordModelWorker::CallDoWorkAndSignalTask, |
28 work, &done)); | 31 work, &done, &error_info)); |
29 done.Wait(); | 32 done.Wait(); |
| 33 return error_info; |
30 } | 34 } |
31 | 35 |
32 void PasswordModelWorker::CallDoWorkAndSignalTask(Callback0::Type* work, | 36 void PasswordModelWorker::CallDoWorkAndSignalTask( |
33 WaitableEvent* done) { | 37 Callback1<UnrecoverableErrorInfo*>::Type* work, |
34 work->Run(); | 38 WaitableEvent* done, |
| 39 UnrecoverableErrorInfo* error_info) { |
| 40 work->Run(error_info); |
35 done->Signal(); | 41 done->Signal(); |
36 } | 42 } |
37 | 43 |
38 ModelSafeGroup PasswordModelWorker::GetModelSafeGroup() { | 44 ModelSafeGroup PasswordModelWorker::GetModelSafeGroup() { |
39 return GROUP_PASSWORD; | 45 return GROUP_PASSWORD; |
40 } | 46 } |
41 | 47 |
42 } // namespace browser_sync | 48 } // namespace browser_sync |
OLD | NEW |