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

Unified Diff: components/bookmarks/core/browser/bookmark_node_data.cc

Issue 284893003: Move bookmarks/core/... to bookmarks/... (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixing errors reported by presubmit Created 6 years, 7 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
Index: components/bookmarks/core/browser/bookmark_node_data.cc
diff --git a/components/bookmarks/core/browser/bookmark_node_data.cc b/components/bookmarks/core/browser/bookmark_node_data.cc
deleted file mode 100644
index 0e356eb2942613a2a84020a13ef69faaa424af52..0000000000000000000000000000000000000000
--- a/components/bookmarks/core/browser/bookmark_node_data.cc
+++ /dev/null
@@ -1,285 +0,0 @@
-// Copyright 2014 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "components/bookmarks/core/browser/bookmark_node_data.h"
-
-#include <string>
-
-#include "base/basictypes.h"
-#include "base/pickle.h"
-#include "base/strings/string_util.h"
-#include "base/strings/utf_string_conversions.h"
-#include "components/bookmarks/core/browser/bookmark_utils.h"
-#include "ui/base/clipboard/scoped_clipboard_writer.h"
-
-const char* BookmarkNodeData::kClipboardFormatString =
- "chromium/x-bookmark-entries";
-
-BookmarkNodeData::Element::Element() : is_url(false), id_(0) {
-}
-
-BookmarkNodeData::Element::Element(const BookmarkNode* node)
- : is_url(node->is_url()),
- url(node->url()),
- title(node->GetTitle()),
- date_added(node->date_added()),
- date_folder_modified(node->date_folder_modified()),
- id_(node->id()) {
- if (node->GetMetaInfoMap())
- meta_info_map = *node->GetMetaInfoMap();
- for (int i = 0; i < node->child_count(); ++i)
- children.push_back(Element(node->GetChild(i)));
-}
-
-BookmarkNodeData::Element::~Element() {
-}
-
-void BookmarkNodeData::Element::WriteToPickle(Pickle* pickle) const {
- pickle->WriteBool(is_url);
- pickle->WriteString(url.spec());
- pickle->WriteString16(title);
- pickle->WriteInt64(id_);
- pickle->WriteUInt64(meta_info_map.size());
- for (BookmarkNode::MetaInfoMap::const_iterator it = meta_info_map.begin();
- it != meta_info_map.end(); ++it) {
- pickle->WriteString(it->first);
- pickle->WriteString(it->second);
- }
- if (!is_url) {
- pickle->WriteUInt64(children.size());
- for (std::vector<Element>::const_iterator i = children.begin();
- i != children.end(); ++i) {
- i->WriteToPickle(pickle);
- }
- }
-}
-
-bool BookmarkNodeData::Element::ReadFromPickle(Pickle* pickle,
- PickleIterator* iterator) {
- std::string url_spec;
- if (!pickle->ReadBool(iterator, &is_url) ||
- !pickle->ReadString(iterator, &url_spec) ||
- !pickle->ReadString16(iterator, &title) ||
- !pickle->ReadInt64(iterator, &id_)) {
- return false;
- }
- url = GURL(url_spec);
- date_added = base::Time();
- date_folder_modified = base::Time();
- meta_info_map.clear();
- uint64 meta_field_count;
- if (!pickle->ReadUInt64(iterator, &meta_field_count))
- return false;
- for (uint64 i = 0; i < meta_field_count; ++i) {
- std::string key;
- std::string value;
- if (!pickle->ReadString(iterator, &key) ||
- !pickle->ReadString(iterator, &value)) {
- return false;
- }
- meta_info_map[key] = value;
- }
- children.clear();
- if (!is_url) {
- uint64 children_count;
- if (!pickle->ReadUInt64(iterator, &children_count))
- return false;
- children.reserve(children_count);
- for (uint64 i = 0; i < children_count; ++i) {
- children.push_back(Element());
- if (!children.back().ReadFromPickle(pickle, iterator))
- return false;
- }
- }
- return true;
-}
-
-// BookmarkNodeData -----------------------------------------------------------
-
-BookmarkNodeData::BookmarkNodeData() {
-}
-
-BookmarkNodeData::BookmarkNodeData(const BookmarkNode* node) {
- elements.push_back(Element(node));
-}
-
-BookmarkNodeData::BookmarkNodeData(
- const std::vector<const BookmarkNode*>& nodes) {
- ReadFromVector(nodes);
-}
-
-BookmarkNodeData::~BookmarkNodeData() {
-}
-
-#if !defined(OS_MACOSX)
-// static
-bool BookmarkNodeData::ClipboardContainsBookmarks() {
- return ui::Clipboard::GetForCurrentThread()->IsFormatAvailable(
- ui::Clipboard::GetFormatType(kClipboardFormatString),
- ui::CLIPBOARD_TYPE_COPY_PASTE);
-}
-#endif
-
-bool BookmarkNodeData::ReadFromVector(
- const std::vector<const BookmarkNode*>& nodes) {
- Clear();
-
- if (nodes.empty())
- return false;
-
- for (size_t i = 0; i < nodes.size(); ++i)
- elements.push_back(Element(nodes[i]));
-
- return true;
-}
-
-bool BookmarkNodeData::ReadFromTuple(const GURL& url, const base::string16& title) {
- Clear();
-
- if (!url.is_valid())
- return false;
-
- Element element;
- element.title = title;
- element.url = url;
- element.is_url = true;
-
- elements.push_back(element);
-
- return true;
-}
-
-#if !defined(OS_MACOSX)
-void BookmarkNodeData::WriteToClipboard(ui::ClipboardType clipboard_type) {
- DCHECK(clipboard_type == ui::CLIPBOARD_TYPE_COPY_PASTE ||
- clipboard_type == ui::CLIPBOARD_TYPE_SELECTION);
- ui::ScopedClipboardWriter scw(ui::Clipboard::GetForCurrentThread(),
- clipboard_type);
-
- // If there is only one element and it is a URL, write the URL to the
- // clipboard.
- if (elements.size() == 1 && elements[0].is_url) {
- const base::string16& title = elements[0].title;
- const std::string url = elements[0].url.spec();
-
- scw.WriteBookmark(title, url);
-
- // Don't call scw.WriteHyperlink() here, since some rich text editors will
- // change fonts when such data is pasted in; besides, most such editors
- // auto-linkify at some point anyway.
-
- // Also write the URL to the clipboard as text so that it can be pasted
- // into text fields. We use WriteText instead of WriteURL because we don't
- // want to clobber the X clipboard when the user copies out of the omnibox
- // on Linux (on Windows and Mac, there is no difference between these
- // functions).
- scw.WriteText(base::UTF8ToUTF16(url));
- }
-
- Pickle pickle;
- WriteToPickle(base::FilePath(), &pickle);
- scw.WritePickledData(pickle,
- ui::Clipboard::GetFormatType(kClipboardFormatString));
-}
-
-bool BookmarkNodeData::ReadFromClipboard(ui::ClipboardType type) {
- DCHECK_EQ(type, ui::CLIPBOARD_TYPE_COPY_PASTE);
- std::string data;
- ui::Clipboard* clipboard = ui::Clipboard::GetForCurrentThread();
- clipboard->ReadData(ui::Clipboard::GetFormatType(kClipboardFormatString),
- &data);
-
- if (!data.empty()) {
- Pickle pickle(data.data(), static_cast<int>(data.size()));
- if (ReadFromPickle(&pickle))
- return true;
- }
-
- base::string16 title;
- std::string url;
- clipboard->ReadBookmark(&title, &url);
- if (!url.empty()) {
- Element element;
- element.is_url = true;
- element.url = GURL(url);
- element.title = title;
-
- elements.clear();
- elements.push_back(element);
- return true;
- }
-
- return false;
-}
-#endif
-
-void BookmarkNodeData::WriteToPickle(const base::FilePath& profile_path,
- Pickle* pickle) const {
- profile_path.WriteToPickle(pickle);
- pickle->WriteUInt64(elements.size());
-
- for (size_t i = 0; i < elements.size(); ++i)
- elements[i].WriteToPickle(pickle);
-}
-
-bool BookmarkNodeData::ReadFromPickle(Pickle* pickle) {
- PickleIterator data_iterator(*pickle);
- uint64 element_count;
- if (profile_path_.ReadFromPickle(&data_iterator) &&
- pickle->ReadUInt64(&data_iterator, &element_count)) {
- std::vector<Element> tmp_elements;
- tmp_elements.resize(element_count);
- for (uint64 i = 0; i < element_count; ++i) {
- if (!tmp_elements[i].ReadFromPickle(pickle, &data_iterator)) {
- return false;
- }
- }
- elements.swap(tmp_elements);
- }
-
- return true;
-}
-
-std::vector<const BookmarkNode*> BookmarkNodeData::GetNodes(
- BookmarkModel* model,
- const base::FilePath& profile_path) const {
- std::vector<const BookmarkNode*> nodes;
-
- if (!IsFromProfilePath(profile_path))
- return nodes;
-
- for (size_t i = 0; i < elements.size(); ++i) {
- const BookmarkNode* node = GetBookmarkNodeByID(model, elements[i].id_);
- if (!node) {
- nodes.clear();
- return nodes;
- }
- nodes.push_back(node);
- }
- return nodes;
-}
-
-const BookmarkNode* BookmarkNodeData::GetFirstNode(
- BookmarkModel* model,
- const base::FilePath& profile_path) const {
- std::vector<const BookmarkNode*> nodes = GetNodes(model, profile_path);
- return nodes.size() == 1 ? nodes[0] : NULL;
-}
-
-void BookmarkNodeData::Clear() {
- profile_path_.clear();
- elements.clear();
-}
-
-void BookmarkNodeData::SetOriginatingProfilePath(
- const base::FilePath& profile_path) {
- DCHECK(profile_path_.empty());
- profile_path_ = profile_path;
-}
-
-bool BookmarkNodeData::IsFromProfilePath(
- const base::FilePath& profile_path) const {
- // An empty path means the data is not associated with any profile.
- return !profile_path_.empty() && profile_path_ == profile_path;
-}
« no previous file with comments | « components/bookmarks/core/browser/bookmark_node_data.h ('k') | components/bookmarks/core/browser/bookmark_node_data_ios.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698