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

Unified Diff: ios/chrome/browser/bookmarks/bookmarks_utils.cc

Issue 1647903002: Moving bookmarks utility function to ios/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 11 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 | « ios/chrome/browser/bookmarks/bookmarks_utils.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ios/chrome/browser/bookmarks/bookmarks_utils.cc
diff --git a/ios/chrome/browser/bookmarks/bookmarks_utils.cc b/ios/chrome/browser/bookmarks/bookmarks_utils.cc
index 97dc51aade11e82a7bfb9dd41f0321e5c7ad07a1..9d4f3785003623b0c3216fc0fcf08140ff6a494f 100644
--- a/ios/chrome/browser/bookmarks/bookmarks_utils.cc
+++ b/ios/chrome/browser/bookmarks/bookmarks_utils.cc
@@ -12,6 +12,9 @@
#include "ios/chrome/browser/pref_names.h"
#include "ios/public/provider/chrome/browser/browser_state/chrome_browser_state.h"
+using bookmarks::BookmarkModel;
+using bookmarks::BookmarkNode;
+
void RecordBookmarkLaunch(BookmarkLaunchLocation launch_location) {
DCHECK(launch_location < BOOKMARK_LAUNCH_LOCATION_COUNT);
UMA_HISTOGRAM_ENUMERATION("Stars.LaunchLocation", launch_location,
@@ -19,7 +22,7 @@ void RecordBookmarkLaunch(BookmarkLaunchLocation launch_location) {
}
bool RemoveAllUserBookmarksIOS(ios::ChromeBrowserState* browser_state) {
- bookmarks::BookmarkModel* bookmark_model =
+ BookmarkModel* bookmark_model =
ios::BookmarkModelFactory::GetForBrowserState(browser_state);
if (!bookmark_model->loaded())
@@ -40,3 +43,55 @@ bool RemoveAllUserBookmarksIOS(ios::ChromeBrowserState* browser_state) {
return true;
}
+
+std::vector<const BookmarkNode*> PrimaryPermanentNodes(BookmarkModel* model) {
+ DCHECK(model->loaded());
+ std::vector<const BookmarkNode*> nodes;
+ nodes.push_back(model->mobile_node());
+ nodes.push_back(model->bookmark_bar_node());
+ nodes.push_back(model->other_node());
+ return nodes;
+}
+
+std::vector<const BookmarkNode*> RootLevelFolders(BookmarkModel* model) {
+ std::vector<const BookmarkNode*> root_level_folders;
+
+ // Find the direct folder children of the primary permanent nodes.
+ std::vector<const BookmarkNode*> primary_permanent_nodes =
+ PrimaryPermanentNodes(model);
+ for (const BookmarkNode* parent : primary_permanent_nodes) {
+ int child_count = parent->child_count();
+ for (int i = 0; i < child_count; ++i) {
+ const BookmarkNode* node = parent->GetChild(i);
+ if (node->is_folder() && node->IsVisible())
+ root_level_folders.push_back(node);
+ }
+ }
+ return root_level_folders;
+}
+
+bool IsPrimaryPermanentNode(const BookmarkNode* node, BookmarkModel* model) {
+ std::vector<const BookmarkNode*> primary_nodes(PrimaryPermanentNodes(model));
+ if (std::find(primary_nodes.begin(), primary_nodes.end(), node) !=
+ primary_nodes.end()) {
+ return true;
+ }
+ return false;
+}
+
+const BookmarkNode* RootLevelFolderForNode(const BookmarkNode* node,
+ BookmarkModel* model) {
+ // This helper function doesn't work for managed bookmarks. This checks that
+ // |node| is editable by the user, which currently covers all the other
+ // bookmarks except the managed bookmarks.
+ DCHECK(model->client()->CanBeEditedByUser(node));
+
+ const std::vector<const BookmarkNode*> root_folders(RootLevelFolders(model));
+ const BookmarkNode* top = node;
+ while (top &&
+ std::find(root_folders.begin(), root_folders.end(), top) ==
+ root_folders.end()) {
+ top = top->parent();
+ }
+ return top;
+}
« no previous file with comments | « ios/chrome/browser/bookmarks/bookmarks_utils.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698