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

Side by Side Diff: components/password_manager/core/browser/password_store_consumer.h

Issue 866983003: GetLoginsRequest: Use ScopedVector to express ownership of forms (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@324291_scopedvector
Patch Set: Rebased Created 5 years, 10 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #ifndef COMPONENTS_PASSWORD_MANAGER_CORE_BROWSER_PASSWORD_STORE_CONSUMER_H_ 5 #ifndef COMPONENTS_PASSWORD_MANAGER_CORE_BROWSER_PASSWORD_STORE_CONSUMER_H_
6 #define COMPONENTS_PASSWORD_MANAGER_CORE_BROWSER_PASSWORD_STORE_CONSUMER_H_ 6 #define COMPONENTS_PASSWORD_MANAGER_CORE_BROWSER_PASSWORD_STORE_CONSUMER_H_
7 7
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/memory/scoped_vector.h"
10 #include "base/task/cancelable_task_tracker.h" 11 #include "base/task/cancelable_task_tracker.h"
11 12
12 namespace autofill { 13 namespace autofill {
13 struct PasswordForm; 14 struct PasswordForm;
14 } 15 }
15 16
16 namespace password_manager { 17 namespace password_manager {
17 18
18 // Reads from the PasswordStore are done asynchronously on a separate 19 // Reads from the PasswordStore are done asynchronously on a separate
19 // thread. PasswordStoreConsumer provides the virtual callback method, which is 20 // thread. PasswordStoreConsumer provides the virtual callback method, which is
20 // guaranteed to be executed on this (the UI) thread. It also provides the 21 // guaranteed to be executed on this (the UI) thread. It also provides the
21 // base::CancelableTaskTracker member, which cancels any outstanding 22 // base::CancelableTaskTracker member, which cancels any outstanding
22 // tasks upon destruction. 23 // tasks upon destruction.
23 class PasswordStoreConsumer { 24 class PasswordStoreConsumer {
24 public: 25 public:
25 PasswordStoreConsumer(); 26 PasswordStoreConsumer();
26 27
27 // Called when the request is finished. If there are no results, it is called 28 // Called when the request is finished. The associated results are accessible
28 // with an empty vector. 29 // through results().
29 // Note: The implementation owns all PasswordForms in the vector. 30 virtual void OnGetPasswordStoreResults() = 0;
vasilii 2015/02/03 19:22:17 This is my deepest concern in the CL. I didn't see
vabr (Chromium) 2015/02/04 16:13:44 Thanks for pointing that out. I agree, and I'm act
30 virtual void OnGetPasswordStoreResults(
31 const std::vector<autofill::PasswordForm*>& results) = 0;
32 31
33 // The base::CancelableTaskTracker can be used for cancelling the 32 // The base::CancelableTaskTracker can be used for cancelling the
34 // tasks associated with the consumer. 33 // tasks associated with the consumer.
35 base::CancelableTaskTracker* cancelable_task_tracker() { 34 base::CancelableTaskTracker* cancelable_task_tracker() {
36 return &cancelable_task_tracker_; 35 return &cancelable_task_tracker_;
37 } 36 }
38 37
39 base::WeakPtr<PasswordStoreConsumer> GetWeakPtr() { 38 base::WeakPtr<PasswordStoreConsumer> GetWeakPtr() {
40 return weak_ptr_factory_.GetWeakPtr(); 39 return weak_ptr_factory_.GetWeakPtr();
41 } 40 }
42 41
42 ScopedVector<autofill::PasswordForm>* results() { return &results_; }
43
43 protected: 44 protected:
44 virtual ~PasswordStoreConsumer(); 45 virtual ~PasswordStoreConsumer();
45 46
46 private: 47 private:
48 ScopedVector<autofill::PasswordForm> results_;
47 base::CancelableTaskTracker cancelable_task_tracker_; 49 base::CancelableTaskTracker cancelable_task_tracker_;
48 base::WeakPtrFactory<PasswordStoreConsumer> weak_ptr_factory_; 50 base::WeakPtrFactory<PasswordStoreConsumer> weak_ptr_factory_;
49 }; 51 };
50 52
51 } // namespace password_manager 53 } // namespace password_manager
52 54
53 #endif // COMPONENTS_PASSWORD_MANAGER_CORE_BROWSER_PASSWORD_STORE_CONSUMER_H_ 55 #endif // COMPONENTS_PASSWORD_MANAGER_CORE_BROWSER_PASSWORD_STORE_CONSUMER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698