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

Side by Side Diff: chrome/browser/bookmarks/chrome_bookmark_client.h

Issue 484213002: Refactor HistoryService to not send NOTIFICATION_FAVICON_CHANGED (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix android unit tests Created 6 years, 3 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | chrome/browser/bookmarks/chrome_bookmark_client.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 CHROME_BROWSER_BOOKMARKS_CHROME_BOOKMARK_CLIENT_H_ 5 #ifndef CHROME_BROWSER_BOOKMARKS_CHROME_BOOKMARK_CLIENT_H_
6 #define CHROME_BROWSER_BOOKMARKS_CHROME_BOOKMARK_CLIENT_H_ 6 #define CHROME_BROWSER_BOOKMARKS_CHROME_BOOKMARK_CLIENT_H_
7 7
8 #include <set>
8 #include <vector> 9 #include <vector>
9 10
11 #include "base/callback_list.h"
10 #include "base/deferred_sequenced_task_runner.h" 12 #include "base/deferred_sequenced_task_runner.h"
11 #include "base/macros.h" 13 #include "base/macros.h"
12 #include "components/bookmarks/browser/base_bookmark_model_observer.h" 14 #include "components/bookmarks/browser/base_bookmark_model_observer.h"
13 #include "components/bookmarks/browser/bookmark_client.h" 15 #include "components/bookmarks/browser/bookmark_client.h"
14 #include "components/policy/core/browser/managed_bookmarks_tracker.h" 16 #include "components/policy/core/browser/managed_bookmarks_tracker.h"
15 #include "content/public/browser/notification_observer.h"
16 #include "content/public/browser/notification_registrar.h"
17 17
18 class BookmarkModel; 18 class BookmarkModel;
19 class GURL;
20 class HistoryService;
21 class HistoryServiceFactory;
19 class Profile; 22 class Profile;
20 23
21 class ChromeBookmarkClient : public bookmarks::BookmarkClient, 24 class ChromeBookmarkClient : public bookmarks::BookmarkClient,
22 public content::NotificationObserver,
23 public BaseBookmarkModelObserver { 25 public BaseBookmarkModelObserver {
24 public: 26 public:
25 explicit ChromeBookmarkClient(Profile* profile); 27 explicit ChromeBookmarkClient(Profile* profile);
26 virtual ~ChromeBookmarkClient(); 28 virtual ~ChromeBookmarkClient();
27 29
28 void Init(BookmarkModel* model); 30 void Init(BookmarkModel* model);
29 31
30 // KeyedService: 32 // KeyedService:
31 virtual void Shutdown() OVERRIDE; 33 virtual void Shutdown() OVERRIDE;
32 34
(...skipping 20 matching lines...) Expand all
53 NodeTypedCountPairs* node_typed_count_pairs) OVERRIDE; 55 NodeTypedCountPairs* node_typed_count_pairs) OVERRIDE;
54 virtual bool IsPermanentNodeVisible( 56 virtual bool IsPermanentNodeVisible(
55 const BookmarkPermanentNode* node) OVERRIDE; 57 const BookmarkPermanentNode* node) OVERRIDE;
56 virtual void RecordAction(const base::UserMetricsAction& action) OVERRIDE; 58 virtual void RecordAction(const base::UserMetricsAction& action) OVERRIDE;
57 virtual bookmarks::LoadExtraCallback GetLoadExtraNodesCallback() OVERRIDE; 59 virtual bookmarks::LoadExtraCallback GetLoadExtraNodesCallback() OVERRIDE;
58 virtual bool CanSetPermanentNodeTitle( 60 virtual bool CanSetPermanentNodeTitle(
59 const BookmarkNode* permanent_node) OVERRIDE; 61 const BookmarkNode* permanent_node) OVERRIDE;
60 virtual bool CanSyncNode(const BookmarkNode* node) OVERRIDE; 62 virtual bool CanSyncNode(const BookmarkNode* node) OVERRIDE;
61 virtual bool CanBeEditedByUser(const BookmarkNode* node) OVERRIDE; 63 virtual bool CanBeEditedByUser(const BookmarkNode* node) OVERRIDE;
62 64
63 // content::NotificationObserver: 65 private:
64 virtual void Observe(int type, 66 friend class HistoryServiceFactory;
65 const content::NotificationSource& source, 67 void SetHistoryService(HistoryService* history_service);
66 const content::NotificationDetails& details) OVERRIDE;
67 68
68 private:
69 // BaseBookmarkModelObserver: 69 // BaseBookmarkModelObserver:
70 virtual void BookmarkModelChanged() OVERRIDE; 70 virtual void BookmarkModelChanged() OVERRIDE;
71 virtual void BookmarkNodeRemoved(BookmarkModel* model, 71 virtual void BookmarkNodeRemoved(BookmarkModel* model,
72 const BookmarkNode* parent, 72 const BookmarkNode* parent,
73 int old_index, 73 int old_index,
74 const BookmarkNode* node, 74 const BookmarkNode* node,
75 const std::set<GURL>& removed_urls) OVERRIDE; 75 const std::set<GURL>& removed_urls) OVERRIDE;
76 virtual void BookmarkAllUserNodesRemoved( 76 virtual void BookmarkAllUserNodesRemoved(
77 BookmarkModel* model, 77 BookmarkModel* model,
78 const std::set<GURL>& removed_urls) OVERRIDE; 78 const std::set<GURL>& removed_urls) OVERRIDE;
79 virtual void BookmarkModelLoaded(BookmarkModel* model, 79 virtual void BookmarkModelLoaded(BookmarkModel* model,
80 bool ids_reassigned) OVERRIDE; 80 bool ids_reassigned) OVERRIDE;
81 81
82 // Helper for GetLoadExtraNodesCallback(). 82 // Helper for GetLoadExtraNodesCallback().
83 static bookmarks::BookmarkPermanentNodeList LoadExtraNodes( 83 static bookmarks::BookmarkPermanentNodeList LoadExtraNodes(
84 scoped_ptr<BookmarkPermanentNode> managed_node, 84 scoped_ptr<BookmarkPermanentNode> managed_node,
85 scoped_ptr<base::ListValue> initial_managed_bookmarks, 85 scoped_ptr<base::ListValue> initial_managed_bookmarks,
86 int64* next_node_id); 86 int64* next_node_id);
87 87
88 // Returns the management domain that configured the managed bookmarks, 88 // Returns the management domain that configured the managed bookmarks,
89 // or an empty string. 89 // or an empty string.
90 std::string GetManagedBookmarksDomain(); 90 std::string GetManagedBookmarksDomain();
91 91
92 Profile* profile_; 92 Profile* profile_;
93 93
94 content::NotificationRegistrar registrar_; 94 // HistoryService associated to the Profile. Due to circular dependency, this
95 // cannot be passed to the constructor, nor lazily fetched. Instead the value
96 // is initialized from HistoryServiceFactory.
97 HistoryService* history_service_;
98
99 scoped_ptr<base::CallbackList<void(const std::set<GURL>&)>::Subscription>
100 favicon_changed_subscription_;
95 101
96 // Pointer to the BookmarkModel. Will be non-NULL from the call to Init to 102 // Pointer to the BookmarkModel. Will be non-NULL from the call to Init to
97 // the call to Shutdown. Must be valid for the whole interval. 103 // the call to Shutdown. Must be valid for the whole interval.
98 BookmarkModel* model_; 104 BookmarkModel* model_;
99 105
100 scoped_ptr<policy::ManagedBookmarksTracker> managed_bookmarks_tracker_; 106 scoped_ptr<policy::ManagedBookmarksTracker> managed_bookmarks_tracker_;
101 BookmarkPermanentNode* managed_node_; 107 BookmarkPermanentNode* managed_node_;
102 108
103 DISALLOW_COPY_AND_ASSIGN(ChromeBookmarkClient); 109 DISALLOW_COPY_AND_ASSIGN(ChromeBookmarkClient);
104 }; 110 };
105 111
106 #endif // CHROME_BROWSER_BOOKMARKS_CHROME_BOOKMARK_CLIENT_H_ 112 #endif // CHROME_BROWSER_BOOKMARKS_CHROME_BOOKMARK_CLIENT_H_
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/bookmarks/chrome_bookmark_client.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698