// Copyright (c) 2012 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.
// This file implements the ScopedClipboardWriter class. Documentation on its
// purpose can be found in our header. Documentation on the format of the
// parameters for each clipboard target can be found in clipboard.h.
#include "ui/base/clipboard/scoped_clipboard_writer.h"
#include "base/pickle.h"
#include "base/strings/utf_string_conversions.h"
#include "net/base/escape.h"
#include "ui/gfx/size.h"
namespace ui {
ScopedClipboardWriter::ScopedClipboardWriter(Clipboard* clipboard,
ClipboardType type)
: clipboard_(clipboard),
type_(type) {
}
ScopedClipboardWriter::~ScopedClipboardWriter() {
if (!objects_.empty() && clipboard_)
clipboard_->WriteObjects(type_, objects_);
}
void ScopedClipboardWriter::WriteText(const base::string16& text) {
WriteTextOrURL(text, false);
}
void ScopedClipboardWriter::WriteURL(const base::string16& text) {
WriteTextOrURL(text, true);
}
void ScopedClipboardWriter::WriteHTML(const base::string16& markup,
const std::string& source_url) {
std::string utf8_markup = base::UTF16ToUTF8(markup);
Clipboard::ObjectMapParams parameters;
parameters.push_back(
Clipboard::ObjectMapParam(utf8_markup.begin(),
utf8_markup.end()));
if (!source_url.empty()) {
parameters.push_back(Clipboard::ObjectMapParam(source_url.begin(),
source_url.end()));
}
objects_[Clipboard::CBF_HTML] = parameters;
}
void ScopedClipboardWriter::WriteRTF(const std::string& rtf_data) {
Clipboard::ObjectMapParams parameters;
parameters.push_back(Clipboard::ObjectMapParam(rtf_data.begin(),
rtf_data.end()));
objects_[Clipboard::CBF_RTF] = parameters;
}
void ScopedClipboardWriter::WriteBookmark(const base::string16& bookmark_title,
const std::string& url) {
if (bookmark_title.empty() || url.empty())
return;
std::string utf8_markup = base::UTF16ToUTF8(bookmark_title);
Clipboard::ObjectMapParams parameters;
parameters.push_back(Clipboard::ObjectMapParam(utf8_markup.begin(),
utf8_markup.end()));
parameters.push_back(Clipboard::ObjectMapParam(url.begin(), url.end()));
objects_[Clipboard::CBF_BOOKMARK] = parameters;
}
void ScopedClipboardWriter::WriteHyperlink(const base::string16& anchor_text,
const std::string& url) {
if (anchor_text.empty() || url.empty())
return;
// Construct the hyperlink.
std::string html("<a href=\"");
html.append(net::EscapeForHTML(url));
html.append("\">");
html.append(net::EscapeForHTML(base::UTF16ToUTF8(anchor_text)));
html.append("</a>");
WriteHTML(base::UTF8ToUTF16(html), std::string());
}
void ScopedClipboardWriter::WriteWebSmartPaste() {
objects_[Clipboard::CBF_WEBKIT] = Clipboard::ObjectMapParams();
}
void ScopedClipboardWriter::WritePickledData(
const Pickle& pickle, const Clipboard::FormatType& format) {
std::string format_string = format.Serialize();
Clipboard::ObjectMapParam format_parameter(format_string.begin(),
format_string.end());
Clipboard::ObjectMapParam data_parameter;
data_parameter.resize(pickle.size());
memcpy(const_cast<char*>(&data_parameter.front()),
pickle.data(), pickle.size());
Clipboard::ObjectMapParams parameters;
parameters.push_back(format_parameter);
parameters.push_back(data_parameter);
objects_[Clipboard::CBF_DATA] = parameters;
}
void ScopedClipboardWriter::Reset() {
url_text_.clear();
objects_.clear();
}
void ScopedClipboardWriter::WriteTextOrURL(const base::string16& text,
bool is_url) {
std::string utf8_text = base::UTF16ToUTF8(text);
Clipboard::ObjectMapParams parameters;
parameters.push_back(Clipboard::ObjectMapParam(utf8_text.begin(),
utf8_text.end()));
objects_[Clipboard::CBF_TEXT] = parameters;
if (is_url) {
url_text_ = utf8_text;
} else {
url_text_.clear();
}
}
} // namespace ui