summaryrefslogtreecommitdiffstats
path: root/chrome/browser/bookmarks
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/bookmarks')
-rw-r--r--chrome/browser/bookmarks/bookmark_model.cc124
-rw-r--r--chrome/browser/bookmarks/bookmark_model.h36
-rw-r--r--chrome/browser/bookmarks/bookmark_model_unittest.cc16
-rw-r--r--chrome/browser/bookmarks/bookmark_table_model.cc13
-rw-r--r--chrome/browser/bookmarks/bookmark_utils.cc114
-rw-r--r--chrome/browser/bookmarks/bookmark_utils.h36
6 files changed, 172 insertions, 167 deletions
diff --git a/chrome/browser/bookmarks/bookmark_model.cc b/chrome/browser/bookmarks/bookmark_model.cc
index 7d8bccc..dd4b1fb 100644
--- a/chrome/browser/bookmarks/bookmark_model.cc
+++ b/chrome/browser/bookmarks/bookmark_model.cc
@@ -5,8 +5,8 @@
#include "chrome/browser/bookmarks/bookmark_model.h"
#include "base/gfx/png_decoder.h"
+#include "chrome/browser/bookmarks/bookmark_utils.h"
#include "chrome/browser/bookmarks/bookmark_storage.h"
-#include "chrome/browser/history/query_parser.h"
#include "chrome/browser/profile.h"
#include "chrome/common/l10n_util.h"
#include "chrome/common/scoped_vector.h"
@@ -15,19 +15,6 @@
using base::Time;
-namespace {
-
-// Functions used for sorting.
-bool MoreRecentlyModified(BookmarkNode* n1, BookmarkNode* n2) {
- return n1->date_group_modified() > n2->date_group_modified();
-}
-
-bool MoreRecentlyAdded(BookmarkNode* n1, BookmarkNode* n2) {
- return n1->date_added() > n2->date_added();
-}
-
-} // namespace
-
// BookmarkNode ---------------------------------------------------------------
namespace {
@@ -139,87 +126,11 @@ void BookmarkModel::Load() {
}
BookmarkNode* BookmarkModel::GetParentForNewNodes() {
- std::vector<BookmarkNode*> nodes;
-
- GetMostRecentlyModifiedGroupNodes(&root_, 1, &nodes);
+ std::vector<BookmarkNode*> nodes =
+ bookmark_utils::GetMostRecentlyModifiedGroups(this, 1);
return nodes.empty() ? bookmark_bar_node_ : nodes[0];
}
-std::vector<BookmarkNode*> BookmarkModel::GetMostRecentlyModifiedGroups(
- size_t max_count) {
- std::vector<BookmarkNode*> nodes;
- GetMostRecentlyModifiedGroupNodes(&root_, max_count, &nodes);
-
- if (nodes.size() < max_count) {
- // Add the bookmark bar and other nodes if there is space.
- if (find(nodes.begin(), nodes.end(), bookmark_bar_node_) == nodes.end())
- nodes.push_back(bookmark_bar_node_);
-
- if (nodes.size() < max_count &&
- find(nodes.begin(), nodes.end(), other_node_) == nodes.end()) {
- nodes.push_back(other_node_);
- }
- }
- return nodes;
-}
-
-void BookmarkModel::GetMostRecentlyAddedEntries(
- size_t count,
- std::vector<BookmarkNode*>* nodes) {
- AutoLock url_lock(url_lock_);
- for (NodesOrderedByURLSet::iterator i = nodes_ordered_by_url_set_.begin();
- i != nodes_ordered_by_url_set_.end(); ++i) {
- std::vector<BookmarkNode*>::iterator insert_position =
- std::upper_bound(nodes->begin(), nodes->end(), *i, &MoreRecentlyAdded);
- if (nodes->size() < count || insert_position != nodes->end()) {
- nodes->insert(insert_position, *i);
- while (nodes->size() > count)
- nodes->pop_back();
- }
- }
-}
-
-void BookmarkModel::GetBookmarksMatchingText(
- const std::wstring& text,
- size_t max_count,
- std::vector<TitleMatch>* matches) {
- QueryParser parser;
- ScopedVector<QueryNode> query_nodes;
- parser.ParseQuery(text, &query_nodes.get());
- if (query_nodes.empty())
- return;
-
- AutoLock url_lock(url_lock_);
- Snippet::MatchPositions match_position;
- for (NodesOrderedByURLSet::iterator i = nodes_ordered_by_url_set_.begin();
- i != nodes_ordered_by_url_set_.end(); ++i) {
- if (parser.DoesQueryMatch((*i)->GetTitle(), query_nodes.get(),
- &match_position)) {
- matches->push_back(TitleMatch());
- matches->back().node = *i;
- matches->back().match_positions.swap(match_position);
- if (matches->size() == max_count)
- break;
- }
- }
-}
-
-bool BookmarkModel::DoesBookmarkMatchText(const std::wstring& text,
- BookmarkNode* node) {
- if (!node->is_url())
- return false;
-
- QueryParser parser;
- ScopedVector<QueryNode> query_nodes;
- parser.ParseQuery(text, &query_nodes.get());
- if (query_nodes.empty())
- return false;
-
- Snippet::MatchPositions match_position;
- return parser.DoesQueryMatch(node->GetTitle(), query_nodes.get(),
- &match_position);
-}
-
void BookmarkModel::Remove(BookmarkNode* parent, int index) {
if (!loaded_ || !IsValidIndex(parent, index, false) || parent == &root_) {
NOTREACHED();
@@ -302,7 +213,7 @@ BookmarkNode* BookmarkModel::GetMostRecentlyAddedNodeForURL(const GURL& url) {
if (nodes.empty())
return NULL;
- std::sort(nodes.begin(), nodes.end(), &MoreRecentlyAdded);
+ std::sort(nodes.begin(), nodes.end(), &bookmark_utils::MoreRecentlyAdded);
return nodes.front();
}
@@ -704,33 +615,6 @@ void BookmarkModel::CancelPendingFavIconLoadRequests(BookmarkNode* node) {
}
}
-void BookmarkModel::GetMostRecentlyModifiedGroupNodes(
- BookmarkNode* parent,
- size_t count,
- std::vector<BookmarkNode*>* nodes) {
- if (parent != &root_ && parent->is_folder() &&
- parent->date_group_modified() > Time()) {
- if (count == 0) {
- nodes->push_back(parent);
- } else {
- std::vector<BookmarkNode*>::iterator i =
- std::upper_bound(nodes->begin(), nodes->end(), parent,
- &MoreRecentlyModified);
- if (nodes->size() < count || i != nodes->end()) {
- nodes->insert(i, parent);
- while (nodes->size() > count)
- nodes->pop_back();
- }
- }
- } // else case, the root node, which we don't care about or imported nodes
- // (which have a time of 0).
- for (int i = 0; i < parent->GetChildCount(); ++i) {
- BookmarkNode* child = parent->GetChild(i);
- if (child->is_folder())
- GetMostRecentlyModifiedGroupNodes(child, count, nodes);
- }
-}
-
void BookmarkModel::Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details) {
diff --git a/chrome/browser/bookmarks/bookmark_model.h b/chrome/browser/bookmarks/bookmark_model.h
index 182d3cc..675405b 100644
--- a/chrome/browser/bookmarks/bookmark_model.h
+++ b/chrome/browser/bookmarks/bookmark_model.h
@@ -190,7 +190,7 @@ class BookmarkModel : public NotificationObserver, public BookmarkService {
public:
explicit BookmarkModel(Profile* profile);
virtual ~BookmarkModel();
-
+
// Loads the bookmarks. This is called by Profile upon creation of the
// BookmarkModel. You need not invoke this directly.
void Load();
@@ -209,34 +209,6 @@ class BookmarkModel : public NotificationObserver, public BookmarkService {
// (as long as the model is loaded).
BookmarkNode* GetParentForNewNodes();
- // Returns a vector containing up to |max_count| of the most recently
- // modified groups. This never returns an empty vector.
- std::vector<BookmarkNode*> GetMostRecentlyModifiedGroups(size_t max_count);
-
- // Returns the most recently added bookmarks. This does not return groups,
- // only nodes of type url.
- void GetMostRecentlyAddedEntries(size_t count,
- std::vector<BookmarkNode*>* nodes);
-
- // Used by GetBookmarksMatchingText to return a matching node and the location
- // of the match in the title.
- struct TitleMatch {
- BookmarkNode* node;
-
- // Location of the matching words in the title of the node.
- Snippet::MatchPositions match_positions;
- };
-
- // Returns the bookmarks whose title contains text. At most |max_count|
- // matches are returned in |matches|.
- void GetBookmarksMatchingText(const std::wstring& text,
- size_t max_count,
- std::vector<TitleMatch>* matches);
-
- // Returns true if the specified bookmark's title matches the specified
- // text.
- bool DoesBookmarkMatchText(const std::wstring& text, BookmarkNode* node);
-
void AddObserver(BookmarkModelObserver* observer) {
observers_.AddObserver(observer);
}
@@ -405,12 +377,6 @@ class BookmarkModel : public NotificationObserver, public BookmarkService {
// If we're waiting on a favicon for node, the load request is canceled.
void CancelPendingFavIconLoadRequests(BookmarkNode* node);
- // Returns up to count of the most recently modified groups. This may not
- // add anything.
- void GetMostRecentlyModifiedGroupNodes(BookmarkNode* parent,
- size_t count,
- std::vector<BookmarkNode*>* nodes);
-
// NotificationObserver.
virtual void Observe(NotificationType type,
const NotificationSource& source,
diff --git a/chrome/browser/bookmarks/bookmark_model_unittest.cc b/chrome/browser/bookmarks/bookmark_model_unittest.cc
index 2136347..a78dec6 100644
--- a/chrome/browser/bookmarks/bookmark_model_unittest.cc
+++ b/chrome/browser/bookmarks/bookmark_model_unittest.cc
@@ -5,6 +5,7 @@
#include "base/string_util.h"
#include "chrome/browser/bookmarks/bookmark_model.h"
#include "chrome/browser/bookmarks/bookmark_codec.h"
+#include "chrome/browser/bookmarks/bookmark_utils.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/notification_registrar.h"
@@ -303,14 +304,15 @@ TEST_F(BookmarkModelTest, MostRecentlyModifiedGroups) {
// Make sure group is in the most recently modified.
std::vector<BookmarkNode*> most_recent_groups =
- model.GetMostRecentlyModifiedGroups(1);
+ bookmark_utils::GetMostRecentlyModifiedGroups(&model, 1);
ASSERT_EQ(1, most_recent_groups.size());
ASSERT_EQ(group, most_recent_groups[0]);
// Nuke the group and do another fetch, making sure group isn't in the
// returned list.
model.Remove(group->GetParent(), 0);
- most_recent_groups = model.GetMostRecentlyModifiedGroups(1);
+ most_recent_groups =
+ bookmark_utils::GetMostRecentlyModifiedGroups(&model, 1);
ASSERT_EQ(1, most_recent_groups.size());
ASSERT_TRUE(most_recent_groups[0] != group);
}
@@ -335,7 +337,7 @@ TEST_F(BookmarkModelTest, MostRecentlyAddedEntries) {
// Make sure order is honored.
std::vector<BookmarkNode*> recently_added;
- model.GetMostRecentlyAddedEntries(2, &recently_added);
+ bookmark_utils::GetMostRecentlyAddedEntries(&model, 2, &recently_added);
ASSERT_EQ(2, recently_added.size());
ASSERT_TRUE(n1 == recently_added[0]);
ASSERT_TRUE(n2 == recently_added[1]);
@@ -343,7 +345,7 @@ TEST_F(BookmarkModelTest, MostRecentlyAddedEntries) {
// swap 1 and 2, then check again.
recently_added.clear();
std::swap(n1->date_added_, n2->date_added_);
- model.GetMostRecentlyAddedEntries(4, &recently_added);
+ bookmark_utils::GetMostRecentlyAddedEntries(&model, 4, &recently_added);
ASSERT_EQ(4, recently_added.size());
ASSERT_TRUE(n2 == recently_added[0]);
ASSERT_TRUE(n1 == recently_added[1]);
@@ -362,13 +364,13 @@ TEST_F(BookmarkModelTest, GetBookmarksMatchingText) {
model.AddGroup(model.GetBookmarkBarNode(), 2, L"blah");
// Make sure we don't get back the folder.
- std::vector<BookmarkModel::TitleMatch> results;
- model.GetBookmarksMatchingText(L"blah", 2, &results);
+ std::vector<bookmark_utils::TitleMatch> results;
+ bookmark_utils::GetBookmarksMatchingText(&model, L"blah", 2, &results);
ASSERT_EQ(1U, results.size());
EXPECT_EQ(n1, results[0].node);
results.clear();
- model.GetBookmarksMatchingText(L"x", 2, &results);
+ bookmark_utils::GetBookmarksMatchingText(&model, L"x", 2, &results);
ASSERT_EQ(1U, results.size());
EXPECT_EQ(n2, results[0].node);
}
diff --git a/chrome/browser/bookmarks/bookmark_table_model.cc b/chrome/browser/bookmarks/bookmark_table_model.cc
index a9122fa..234628d 100644
--- a/chrome/browser/bookmarks/bookmark_table_model.cc
+++ b/chrome/browser/bookmarks/bookmark_table_model.cc
@@ -10,6 +10,7 @@
#include "base/time.h"
#include "base/time_format.h"
#include "chrome/app/theme/theme_resources.h"
+#include "chrome/browser/bookmarks/bookmark_utils.h"
#include "chrome/common/resource_bundle.h"
#include "googleurl/src/gurl.h"
@@ -185,7 +186,9 @@ class RecentlyBookmarkedTableModel : public VectorBackedBookmarkTableModel {
private:
void UpdateRecentlyBookmarked() {
nodes().clear();
- model()->GetMostRecentlyAddedEntries(kRecentlyBookmarkedCount, &nodes());
+ bookmark_utils::GetMostRecentlyAddedEntries(model(),
+ kRecentlyBookmarkedCount,
+ &nodes());
if (observer())
observer()->OnModelChanged();
}
@@ -201,9 +204,9 @@ class BookmarkSearchTableModel : public VectorBackedBookmarkTableModel {
const std::wstring& search_text)
: VectorBackedBookmarkTableModel(model),
search_text_(search_text) {
- std::vector<BookmarkModel::TitleMatch> matches;
- model->GetBookmarksMatchingText(search_text,
- std::numeric_limits<int>::max(), &matches);
+ std::vector<bookmark_utils::TitleMatch> matches;
+ bookmark_utils::GetBookmarksMatchingText(
+ model, search_text, std::numeric_limits<int>::max(), &matches);
for (size_t i = 0; i < matches.size(); ++i)
nodes().push_back(matches[i].node);
}
@@ -212,7 +215,7 @@ class BookmarkSearchTableModel : public VectorBackedBookmarkTableModel {
BookmarkNode* parent,
int index) {
BookmarkNode* node = parent->GetChild(index);
- if (model->DoesBookmarkMatchText(search_text_, node)) {
+ if (bookmark_utils::DoesBookmarkMatchText(search_text_, node)) {
nodes().push_back(node);
if (observer())
observer()->OnItemsAdded(static_cast<int>(nodes().size() - 1), 1);
diff --git a/chrome/browser/bookmarks/bookmark_utils.cc b/chrome/browser/bookmarks/bookmark_utils.cc
index 9e0b7c8..1a25556 100644
--- a/chrome/browser/bookmarks/bookmark_utils.cc
+++ b/chrome/browser/bookmarks/bookmark_utils.cc
@@ -4,16 +4,19 @@
#include "chrome/browser/bookmarks/bookmark_utils.h"
+#include "base/time.h"
#include "chrome/browser/bookmarks/bookmark_drag_data.h"
#include "chrome/browser/bookmarks/bookmark_model.h"
#include "chrome/browser/browser.h"
#include "chrome/browser/browser_list.h"
+#include "chrome/browser/history/query_parser.h"
#include "chrome/browser/page_navigator.h"
#include "chrome/browser/tab_contents.h"
#include "chrome/common/drag_drop_types.h"
#include "chrome/common/l10n_util.h"
#include "chrome/common/os_exchange_data.h"
#include "chrome/views/event.h"
+#include "chrome/views/tree_node_iterator.h"
#include "chromium_strings.h"
#include "generated_resources.h"
@@ -138,6 +141,11 @@ bool ShouldOpenAll(HWND parent, const std::vector<BookmarkNode*>& nodes) {
MB_YESNO | MB_ICONWARNING | MB_TOPMOST) == IDYES;
}
+// Comparison function that compares based on date modified of the two nodes.
+bool MoreRecentlyModified(BookmarkNode* n1, BookmarkNode* n2) {
+ return n1->date_group_modified() > n2->date_group_modified();
+}
+
} // namespace
namespace bookmark_utils {
@@ -289,4 +297,110 @@ bool CanPasteFromClipboard(BookmarkNode* node) {
return bookmark_data.Read(data_wrapper);
}
+std::vector<BookmarkNode*> GetMostRecentlyModifiedGroups(
+ BookmarkModel* model,
+ size_t max_count) {
+ std::vector<BookmarkNode*> nodes;
+ views::TreeNodeIterator<BookmarkNode> iterator(model->root_node());
+ while (iterator.has_next()) {
+ BookmarkNode* parent = iterator.Next();
+ if (parent->is_folder() && parent->date_group_modified() > base::Time()) {
+ if (max_count == 0) {
+ nodes.push_back(parent);
+ } else {
+ std::vector<BookmarkNode*>::iterator i =
+ std::upper_bound(nodes.begin(), nodes.end(), parent,
+ &MoreRecentlyModified);
+ if (nodes.size() < max_count || i != nodes.end()) {
+ nodes.insert(i, parent);
+ while (nodes.size() > max_count)
+ nodes.pop_back();
+ }
+ }
+ } // else case, the root node, which we don't care about or imported nodes
+ // (which have a time of 0).
+ }
+
+ if (nodes.size() < max_count) {
+ // Add the bookmark bar and other nodes if there is space.
+ if (find(nodes.begin(), nodes.end(), model->GetBookmarkBarNode()) ==
+ nodes.end()) {
+ nodes.push_back(model->GetBookmarkBarNode());
+ }
+
+ if (nodes.size() < max_count &&
+ find(nodes.begin(), nodes.end(), model->other_node()) == nodes.end()) {
+ nodes.push_back(model->other_node());
+ }
+ }
+ return nodes;
+}
+
+void GetMostRecentlyAddedEntries(BookmarkModel* model,
+ size_t count,
+ std::vector<BookmarkNode*>* nodes) {
+ views::TreeNodeIterator<BookmarkNode> iterator(model->root_node());
+ while (iterator.has_next()) {
+ BookmarkNode* node = iterator.Next();
+ if (node->is_url()) {
+ std::vector<BookmarkNode*>::iterator insert_position =
+ std::upper_bound(nodes->begin(), nodes->end(), node,
+ &MoreRecentlyAdded);
+ if (nodes->size() < count || insert_position != nodes->end()) {
+ nodes->insert(insert_position, node);
+ while (nodes->size() > count)
+ nodes->pop_back();
+ }
+ }
+ }
+}
+
+void GetBookmarksMatchingText(BookmarkModel* model,
+ const std::wstring& text,
+ size_t max_count,
+ std::vector<TitleMatch>* matches) {
+ QueryParser parser;
+ ScopedVector<QueryNode> query_nodes;
+ parser.ParseQuery(text, &query_nodes.get());
+ if (query_nodes.empty())
+ return;
+
+ views::TreeNodeIterator<BookmarkNode> iterator(model->root_node());
+ Snippet::MatchPositions match_position;
+ while (iterator.has_next()) {
+ BookmarkNode* node = iterator.Next();
+ if (node->GetURL().spec() == "http://www.google.com/") {
+ DLOG(INFO) << "BLAH";
+ }
+ if (node->is_url() &&
+ parser.DoesQueryMatch(node->GetTitle(), query_nodes.get(),
+ &match_position)) {
+ matches->push_back(TitleMatch());
+ matches->back().node = node;
+ matches->back().match_positions.swap(match_position);
+ if (matches->size() == max_count)
+ break;
+ }
+ }
+}
+
+bool DoesBookmarkMatchText(const std::wstring& text, BookmarkNode* node) {
+ if (!node->is_url())
+ return false;
+
+ QueryParser parser;
+ ScopedVector<QueryNode> query_nodes;
+ parser.ParseQuery(text, &query_nodes.get());
+ if (query_nodes.empty())
+ return false;
+
+ Snippet::MatchPositions match_position;
+ return parser.DoesQueryMatch(node->GetTitle(), query_nodes.get(),
+ &match_position);
+}
+
+bool MoreRecentlyAdded(BookmarkNode* n1, BookmarkNode* n2) {
+ return n1->date_added() > n2->date_added();
+}
+
} // namespace bookmark_utils
diff --git a/chrome/browser/bookmarks/bookmark_utils.h b/chrome/browser/bookmarks/bookmark_utils.h
index 1d92e3e..9405919 100644
--- a/chrome/browser/bookmarks/bookmark_utils.h
+++ b/chrome/browser/bookmarks/bookmark_utils.h
@@ -8,8 +8,10 @@
#include <vector>
#include "chrome/browser/bookmarks/bookmark_drag_data.h"
+#include "chrome/browser/history/snippet.h"
#include "webkit/glue/window_open_disposition.h"
+class BookmarkModel;
class BookmarkNode;
class PageNavigator;
class Profile;
@@ -75,6 +77,40 @@ void PasteFromClipboard(BookmarkModel* model,
// Returns true if the user can copy from the pasteboard.
bool CanPasteFromClipboard(BookmarkNode* node);
+// Returns a vector containing up to |max_count| of the most recently modified
+// groups. This never returns an empty vector.
+std::vector<BookmarkNode*> GetMostRecentlyModifiedGroups(BookmarkModel* model,
+ size_t max_count);
+
+// Returns the most recently added bookmarks. This does not return groups,
+// only nodes of type url.
+void GetMostRecentlyAddedEntries(BookmarkModel* model,
+ size_t count,
+ std::vector<BookmarkNode*>* nodes);
+
+// Used by GetBookmarksMatchingText to return a matching node and the location
+// of the match in the title.
+struct TitleMatch {
+ BookmarkNode* node;
+
+ // Location of the matching words in the title of the node.
+ Snippet::MatchPositions match_positions;
+};
+
+// Returns the bookmarks whose title contains text. At most |max_count|
+// matches are returned in |matches|.
+void GetBookmarksMatchingText(BookmarkModel* model,
+ const std::wstring& text,
+ size_t max_count,
+ std::vector<TitleMatch>* matches);
+
+// Returns true if the specified bookmark's title matches the specified
+// text.
+bool DoesBookmarkMatchText(const std::wstring& text, BookmarkNode* node);
+
+// Returns true if |n1| was added more recently than |n2|.
+bool MoreRecentlyAdded(BookmarkNode* n1, BookmarkNode* n2);
+
// Number of bookmarks we'll open before prompting the user to see if they
// really want to open all.
//