summaryrefslogtreecommitdiffstats
path: root/chrome/browser/extensions/extension_bookmarks_module.cc
diff options
context:
space:
mode:
authorfeldstein@chromium.org <feldstein@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-04-02 06:45:31 +0000
committerfeldstein@chromium.org <feldstein@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-04-02 06:45:31 +0000
commit9b0718510886b13ee0ff6a2248285cbba2f08d1c (patch)
tree83295ada4204fd086a76ba869868b957214fac20 /chrome/browser/extensions/extension_bookmarks_module.cc
parent4b6bcfac8cd147db4650b7a88f6bc1fe17342e5b (diff)
downloadchromium_src-9b0718510886b13ee0ff6a2248285cbba2f08d1c.zip
chromium_src-9b0718510886b13ee0ff6a2248285cbba2f08d1c.tar.gz
chromium_src-9b0718510886b13ee0ff6a2248285cbba2f08d1c.tar.bz2
Add a folders_only and subtree api to bookmark manager
Adds a new API to the experimental.bookmarkManager namespace getSubtree(id, foldersOnly, callback) Which returns any subtree, and if foldersOnly is true, only returns the folders. At this point, only the bookmark tree is using the new call. BUG=39877 TEST=ExtensionBookmarksTest.* Review URL: http://codereview.chromium.org/1611001 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@43461 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/extensions/extension_bookmarks_module.cc')
-rw-r--r--chrome/browser/extensions/extension_bookmarks_module.cc107
1 files changed, 16 insertions, 91 deletions
diff --git a/chrome/browser/extensions/extension_bookmarks_module.cc b/chrome/browser/extensions/extension_bookmarks_module.cc
index 2d09ef9..6a8cd08 100644
--- a/chrome/browser/extensions/extension_bookmarks_module.cc
+++ b/chrome/browser/extensions/extension_bookmarks_module.cc
@@ -13,6 +13,7 @@
#include "chrome/browser/bookmarks/bookmark_model.h"
#include "chrome/browser/bookmarks/bookmark_utils.h"
#include "chrome/browser/browser_list.h"
+#include "chrome/browser/extensions/extension_bookmark_helpers.h"
#include "chrome/browser/extensions/extension_bookmarks_module_constants.h"
#include "chrome/browser/extensions/extension_message_service.h"
#include "chrome/browser/extensions/extensions_quota_service.h"
@@ -33,86 +34,6 @@ typedef ExtensionsQuotaService::TimedLimit TimedLimit;
typedef ExtensionsQuotaService::SustainedLimit SustainedLimit;
typedef QuotaLimitHeuristic::BucketMapper BucketMapper;
-// Helper functions.
-class ExtensionBookmarks {
- public:
- // Convert |node| into a JSON value.
- static DictionaryValue* GetNodeDictionary(const BookmarkNode* node,
- bool recurse) {
- DictionaryValue* dict = new DictionaryValue();
- dict->SetString(keys::kIdKey, Int64ToString(node->id()));
-
- const BookmarkNode* parent = node->GetParent();
- if (parent) {
- dict->SetString(keys::kParentIdKey, Int64ToString(parent->id()));
- dict->SetInteger(keys::kIndexKey, parent->IndexOfChild(node));
- }
-
- if (!node->is_folder()) {
- dict->SetString(keys::kUrlKey, node->GetURL().spec());
- } else {
- // Javascript Date wants milliseconds since the epoch, ToDoubleT is
- // seconds.
- base::Time t = node->date_group_modified();
- if (!t.is_null())
- dict->SetReal(keys::kDateGroupModifiedKey, floor(t.ToDoubleT() * 1000));
- }
-
- dict->SetString(keys::kTitleKey, node->GetTitle());
- if (!node->date_added().is_null()) {
- // Javascript Date wants milliseconds since the epoch, ToDoubleT is
- // seconds.
- dict->SetReal(keys::kDateAddedKey,
- floor(node->date_added().ToDoubleT() * 1000));
- }
-
- if (recurse && node->is_folder()) {
- int childCount = node->GetChildCount();
- ListValue* children = new ListValue();
- for (int i = 0; i < childCount; ++i) {
- const BookmarkNode* child = node->GetChild(i);
- DictionaryValue* dict = GetNodeDictionary(child, true);
- children->Append(dict);
- }
- dict->Set(keys::kChildrenKey, children);
- }
- return dict;
- }
-
- // Add a JSON representation of |node| to the JSON |list|.
- static void AddNode(const BookmarkNode* node, ListValue* list, bool recurse) {
- DictionaryValue* dict = GetNodeDictionary(node, recurse);
- list->Append(dict);
- }
-
- static bool RemoveNode(BookmarkModel* model, int64 id, bool recursive,
- std::string* error) {
- const BookmarkNode* node = model->GetNodeByID(id);
- if (!node) {
- *error = keys::kNoNodeError;
- return false;
- }
- if (node == model->root_node() ||
- node == model->other_node() ||
- node == model->GetBookmarkBarNode()) {
- *error = keys::kModifySpecialError;
- return false;
- }
- if (node->is_folder() && node->GetChildCount() > 0 && !recursive) {
- *error = keys::kFolderNotEmptyError;
- return false;
- }
-
- const BookmarkNode* parent = node->GetParent();
- int index = parent->IndexOfChild(node);
- model->Remove(parent, index);
- return true;
- }
-
- private:
- ExtensionBookmarks();
-};
-
void BookmarksFunction::Run() {
BookmarkModel* model = profile()->GetBookmarkModel();
if (!model->IsLoaded()) {
@@ -211,7 +132,8 @@ void ExtensionBookmarkEventRouter::BookmarkNodeAdded(BookmarkModel* model,
ListValue args;
const BookmarkNode* node = parent->GetChild(index);
args.Append(new StringValue(Int64ToString(node->id())));
- DictionaryValue* obj = ExtensionBookmarks::GetNodeDictionary(node, false);
+ DictionaryValue* obj =
+ extension_bookmark_helpers::GetNodeDictionary(node, false, false);
args.Append(obj);
std::string json_args;
@@ -321,7 +243,7 @@ bool GetBookmarksFunction::RunImpl() {
error_ = keys::kNoNodeError;
return false;
} else {
- ExtensionBookmarks::AddNode(node, json.get(), false);
+ extension_bookmark_helpers::AddNode(node, json.get(), false);
}
}
} else {
@@ -335,7 +257,7 @@ bool GetBookmarksFunction::RunImpl() {
error_ = keys::kNoNodeError;
return false;
}
- ExtensionBookmarks::AddNode(node, json.get(), false);
+ extension_bookmark_helpers::AddNode(node, json.get(), false);
}
result_.reset(json.release());
@@ -358,7 +280,7 @@ bool GetBookmarkChildrenFunction::RunImpl() {
int child_count = node->GetChildCount();
for (int i = 0; i < child_count; ++i) {
const BookmarkNode* child = node->GetChild(i);
- ExtensionBookmarks::AddNode(child, json.get(), false);
+ extension_bookmark_helpers::AddNode(child, json.get(), false);
}
result_.reset(json.release());
@@ -379,7 +301,7 @@ bool GetBookmarkRecentFunction::RunImpl() {
std::vector<const BookmarkNode*>::iterator i = nodes.begin();
for (; i != nodes.end(); ++i) {
const BookmarkNode* node = *i;
- ExtensionBookmarks::AddNode(node, json, false);
+ extension_bookmark_helpers::AddNode(node, json, false);
}
result_.reset(json);
return true;
@@ -389,7 +311,7 @@ bool GetBookmarkTreeFunction::RunImpl() {
BookmarkModel* model = profile()->GetBookmarkModel();
scoped_ptr<ListValue> json(new ListValue());
const BookmarkNode* node = model->root_node();
- ExtensionBookmarks::AddNode(node, json.get(), true);
+ extension_bookmark_helpers::AddNode(node, json.get(), true);
result_.reset(json.release());
return true;
}
@@ -410,7 +332,7 @@ bool SearchBookmarksFunction::RunImpl() {
std::vector<const BookmarkNode*>::iterator i = nodes.begin();
for (; i != nodes.end(); ++i) {
const BookmarkNode* node = *i;
- ExtensionBookmarks::AddNode(node, json, false);
+ extension_bookmark_helpers::AddNode(node, json, false);
}
result_.reset(json);
@@ -466,7 +388,7 @@ bool RemoveBookmarkFunction::RunImpl() {
size_t count = ids.size();
EXTENSION_FUNCTION_VALIDATE(count > 0);
for (std::list<int64>::iterator it = ids.begin(); it != ids.end(); ++it) {
- if (!ExtensionBookmarks::RemoveNode(model, *it, recursive, &error_))
+ if (!extension_bookmark_helpers::RemoveNode(model, *it, recursive, &error_))
return false;
}
return true;
@@ -530,7 +452,8 @@ bool CreateBookmarkFunction::RunImpl() {
return false;
}
- DictionaryValue* ret = ExtensionBookmarks::GetNodeDictionary(node, false);
+ DictionaryValue* ret =
+ extension_bookmark_helpers::GetNodeDictionary(node, false, false);
result_.reset(ret);
return true;
@@ -609,7 +532,8 @@ bool MoveBookmarkFunction::RunImpl() {
model->Move(node, parent, index);
- DictionaryValue* ret = ExtensionBookmarks::GetNodeDictionary(node, false);
+ DictionaryValue* ret =
+ extension_bookmark_helpers::GetNodeDictionary(node, false, false);
result_.reset(ret);
return true;
@@ -680,7 +604,8 @@ bool UpdateBookmarkFunction::RunImpl() {
if (!url.is_empty())
model->SetURL(node, url);
- DictionaryValue* ret = ExtensionBookmarks::GetNodeDictionary(node, false);
+ DictionaryValue* ret =
+ extension_bookmark_helpers::GetNodeDictionary(node, false, false);
result_.reset(ret);
return true;