summaryrefslogtreecommitdiffstats
path: root/webkit
diff options
context:
space:
mode:
authordcheng@chromium.org <dcheng@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-02-17 07:48:39 +0000
committerdcheng@chromium.org <dcheng@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-02-17 07:48:39 +0000
commit46ee2f5b64de5fe238bc811c21a2128fa0b0a83f (patch)
tree1e5b431ee48a4bc35be240dba5471afa099ff3ab /webkit
parentb9ab386222d61aa678fabd0f808d8c3828ddf900 (diff)
downloadchromium_src-46ee2f5b64de5fe238bc811c21a2128fa0b0a83f.zip
chromium_src-46ee2f5b64de5fe238bc811c21a2128fa0b0a83f.tar.gz
chromium_src-46ee2f5b64de5fe238bc811c21a2128fa0b0a83f.tar.bz2
Update WebClipboard/WebDropData glue to use new getter/setters for WebDragData.
This change will help us implement the HTML spec for DataTransferItemList correctly. BUG=112255 TEST=manual + WebKit layout tests Committed: https://src.chromium.org/viewvc/chrome?view=rev&revision=122370 Review URL: https://chromiumcodereview.appspot.com/9318003 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@122469 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit')
-rw-r--r--webkit/glue/webdropdata.cc133
-rw-r--r--webkit/tools/test_shell/mock_webclipboard_impl.cc73
-rw-r--r--webkit/tools/test_shell/mock_webclipboard_impl.h9
-rw-r--r--webkit/tools/test_shell/test_webview_delegate.cc9
4 files changed, 155 insertions, 69 deletions
diff --git a/webkit/glue/webdropdata.cc b/webkit/glue/webdropdata.cc
index 53e16d4..02cd419 100644
--- a/webkit/glue/webdropdata.cc
+++ b/webkit/glue/webdropdata.cc
@@ -6,39 +6,57 @@
#include <utility>
+#include "base/string_util.h"
+#include "base/logging.h"
+#include "base/utf_string_conversions.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebData.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebDragData.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebString.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebURL.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebVector.h"
+#include "ui/base/clipboard/clipboard.h"
using WebKit::WebData;
using WebKit::WebDragData;
using WebKit::WebString;
using WebKit::WebVector;
-WebDropData::WebDropData(const WebDragData& drag_data)
- : url(drag_data.url()),
- url_title(drag_data.urlTitle()),
- download_metadata(drag_data.downloadMetadata()),
- plain_text(drag_data.plainText()),
- text_html(drag_data.htmlText()),
- html_base_url(drag_data.htmlBaseURL()),
- file_description_filename(drag_data.fileContentFilename()) {
- if (drag_data.containsFilenames()) {
- WebVector<WebString> filenames_copy;
- drag_data.filenames(filenames_copy);
- for (size_t i = 0; i < filenames_copy.size(); ++i)
- filenames.push_back(filenames_copy[i]);
- }
- WebData contents = drag_data.fileContent();
- if (!contents.isEmpty())
- file_contents.assign(contents.data(), contents.size());
- const WebVector<WebDragData::CustomData>& custom_data_alias =
- drag_data.customData();
- for (size_t i = 0; i < custom_data_alias.size(); ++i) {
- custom_data.insert(std::make_pair(custom_data_alias[i].type,
- custom_data_alias[i].data));
+WebDropData::WebDropData(const WebDragData& drag_data) {
+ const WebVector<WebDragData::Item>& item_list = drag_data.items();
+ for (size_t i = 0; i < item_list.size(); ++i) {
+ const WebDragData::Item& item = item_list[i];
+ switch (item.storageType) {
+ case WebDragData::Item::StorageTypeString: {
+ if (EqualsASCII(item.stringType, ui::Clipboard::kMimeTypeText)) {
+ plain_text = item.stringData;
+ break;
+ }
+ if (EqualsASCII(item.stringType, ui::Clipboard::kMimeTypeURIList)) {
+ url = GURL(item.stringData);
+ url_title = item.title;
+ break;
+ }
+ if (EqualsASCII(item.stringType, ui::Clipboard::kMimeTypeDownloadURL)) {
+ download_metadata = item.stringData;
+ break;
+ }
+ if (EqualsASCII(item.stringType, ui::Clipboard::kMimeTypeHTML)) {
+ text_html = item.stringData;
+ html_base_url = item.baseURL;
+ break;
+ }
+ custom_data.insert(std::make_pair(item.stringType, item.stringData));
+ break;
+ }
+ case WebDragData::Item::StorageTypeBinaryData:
+ file_contents.assign(item.binaryData.data(),
+ item.binaryData.size());
+ file_description_filename = item.title;
+ break;
+ case WebDragData::Item::StorageTypeFilename:
+ // We don't currently use this.
+ NOTREACHED();
+ };
}
}
@@ -49,28 +67,65 @@ WebDropData::~WebDropData() {
}
WebDragData WebDropData::ToDragData() const {
+ std::vector<WebDragData::Item> item_list;
+
+ // These fields are currently unused when dragging into WebKit.
+ DCHECK(download_metadata.empty());
+ DCHECK(file_contents.empty());
+ DCHECK(file_description_filename.empty());
+
+ // TODO(dcheng): We need a way to distinguish between null and empty strings.
+ if (!plain_text.empty()) {
+ WebDragData::Item item;
+ item.storageType = WebDragData::Item::StorageTypeString;
+ item.stringType = WebString::fromUTF8(ui::Clipboard::kMimeTypeText);
+ item.stringData = plain_text;
+ item_list.push_back(item);
+ }
+
+ if (!url.is_empty()) {
+ WebDragData::Item item;
+ item.storageType = WebDragData::Item::StorageTypeString;
+ item.stringType = WebString::fromUTF8(ui::Clipboard::kMimeTypeURIList);
+ item.stringData = WebString::fromUTF8(url.spec());
+ item.title = url_title;
+ item_list.push_back(item);
+ }
+
+ if (!text_html.empty()) {
+ WebDragData::Item item;
+ item.storageType = WebDragData::Item::StorageTypeString;
+ item.stringType = WebString::fromUTF8(ui::Clipboard::kMimeTypeHTML);
+ item.stringData = text_html;
+ item.baseURL = html_base_url;
+ item_list.push_back(item);
+ }
+
+ for (std::vector<string16>::const_iterator it = filenames.begin();
+ it != filenames.end();
+ ++it) {
+ WebDragData::Item item;
+ item.storageType = WebDragData::Item::StorageTypeFilename;
+ item.filenameData = *it;
+ item_list.push_back(item);
+ }
+
+ for (std::map<string16, string16>::const_iterator it = custom_data.begin();
+ it != custom_data.end();
+ ++it) {
+ WebDragData::Item item;
+ item.storageType = WebDragData::Item::StorageTypeString;
+ item.stringType = it->first;
+ item.stringData = it->second;
+ item_list.push_back(item);
+ }
+
WebDragData result;
result.initialize();
- result.setURL(url);
- result.setURLTitle(url_title);
- result.setFilenames(filenames);
+ result.setItems(item_list);
#ifdef WEBKIT_DRAG_DROP_SUPPORT_FILESYSTEM
// TODO(kinuko): remove this ifdef once we update the WebKit API.
result.setFilesystemId(filesystem_id);
#endif
- result.setPlainText(plain_text);
- result.setHTMLText(text_html);
- result.setHTMLBaseURL(html_base_url);
- result.setFileContentFilename(file_description_filename);
- result.setFileContent(WebData(file_contents.data(), file_contents.size()));
- WebVector<WebDragData::CustomData> custom_data_vector(custom_data.size());
- size_t i = 0;
- for (std::map<string16, string16>::const_iterator it = custom_data.begin();
- it != custom_data.end();
- ++it, ++i) {
- WebDragData::CustomData data = {it->first, it->second};
- custom_data_vector[i] = data;
- }
- result.setCustomData(custom_data_vector);
return result;
}
diff --git a/webkit/tools/test_shell/mock_webclipboard_impl.cc b/webkit/tools/test_shell/mock_webclipboard_impl.cc
index 4f67c707..f36e232 100644
--- a/webkit/tools/test_shell/mock_webclipboard_impl.cc
+++ b/webkit/tools/test_shell/mock_webclipboard_impl.cc
@@ -9,11 +9,12 @@
#include "base/logging.h"
#include "base/stl_util.h"
#include "base/string_util.h"
-#include "net/base/escape.h"
+#include "base/utf_string_conversions.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebCommon.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebDragData.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebImage.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebURL.h"
+#include "ui/base/clipboard/clipboard.h"
#include "webkit/glue/webclipboard_impl.h"
#include "webkit/glue/webkit_glue.h"
#include "webkit/support/webkit_support_gfx.h"
@@ -78,10 +79,11 @@ WebVector<WebString> MockWebClipboardImpl::readAvailableTypes(
if (!m_image.isNull()) {
results.push_back(WebString("image/png"));
}
- for (size_t i = 0; i < m_customData.size(); ++i) {
- CHECK(std::find(results.begin(), results.end(), m_customData[i].type) ==
+ for (std::map<string16, string16>::const_iterator it = m_customData.begin();
+ it != m_customData.end(); ++it) {
+ CHECK(std::find(results.begin(), results.end(), it->first) ==
results.end());
- results.push_back(m_customData[i].type);
+ results.push_back(it->first);
}
return results;
}
@@ -135,58 +137,79 @@ WebKit::WebData MockWebClipboardImpl::readImage(
WebKit::WebString MockWebClipboardImpl::readCustomData(
WebKit::WebClipboard::Buffer buffer,
const WebKit::WebString& type) {
- for (size_t i = 0; i < m_customData.size(); ++i) {
- if (m_customData[i].type == type) {
- return m_customData[i].data;
- }
- }
+ std::map<string16, string16>::const_iterator it = m_customData.find(type);
+ if (it != m_customData.end())
+ return it->second;
return WebKit::WebString();
}
void MockWebClipboardImpl::writeHTML(
const WebKit::WebString& htmlText, const WebKit::WebURL& url,
const WebKit::WebString& plainText, bool writeSmartPaste) {
+ clear();
+
m_htmlText = htmlText;
m_plainText = plainText;
- m_image.reset();
- m_customData = WebVector<WebDragData::CustomData>();
m_writeSmartPaste = writeSmartPaste;
}
void MockWebClipboardImpl::writePlainText(const WebKit::WebString& plain_text) {
- m_htmlText = WebKit::WebString();
+ clear();
+
m_plainText = plain_text;
- m_image.reset();
- m_customData = WebVector<WebDragData::CustomData>();
- m_writeSmartPaste = false;
}
void MockWebClipboardImpl::writeURL(
const WebKit::WebURL& url, const WebKit::WebString& title) {
+ clear();
+
m_htmlText = WebString::fromUTF8(
webkit_glue::WebClipboardImpl::URLToMarkup(url, title));
m_plainText = url.spec().utf16();
- m_image.reset();
- m_customData = WebVector<WebDragData::CustomData>();
- m_writeSmartPaste = false;
}
void MockWebClipboardImpl::writeImage(const WebKit::WebImage& image,
const WebKit::WebURL& url, const WebKit::WebString& title) {
if (!image.isNull()) {
+ clear();
+
+ m_plainText = m_htmlText;
m_htmlText = WebString::fromUTF8(
webkit_glue::WebClipboardImpl::URLToImageMarkup(url, title));
- m_plainText = m_htmlText;
m_image = image;
- m_customData = WebVector<WebDragData::CustomData>();
- m_writeSmartPaste = false;
}
}
-void MockWebClipboardImpl::writeDataObject(const WebKit::WebDragData& data) {
- m_htmlText = data.htmlText();
- m_plainText = data.plainText();
+void MockWebClipboardImpl::writeDataObject(const WebDragData& data) {
+ clear();
+
+ const WebVector<WebDragData::Item>& itemList = data.items();
+ for (size_t i = 0; i < itemList.size(); ++i) {
+ const WebDragData::Item& item = itemList[i];
+ switch (item.storageType) {
+ case WebDragData::Item::StorageTypeString: {
+ if (EqualsASCII(item.stringType, ui::Clipboard::kMimeTypeText)) {
+ m_plainText = item.stringData;
+ continue;
+ }
+ if (EqualsASCII(item.stringType, ui::Clipboard::kMimeTypeHTML)) {
+ m_htmlText = item.stringData;
+ continue;
+ }
+ m_customData.insert(std::make_pair(item.stringType, item.stringData));
+ continue;
+ }
+ case WebDragData::Item::StorageTypeFilename:
+ case WebDragData::Item::StorageTypeBinaryData:
+ NOTREACHED(); // Currently unused by the clipboard implementation.
+ }
+ }
+}
+
+void MockWebClipboardImpl::clear() {
+ m_plainText = WebString();
+ m_htmlText = WebString();
m_image.reset();
- m_customData = data.customData();
+ m_customData.clear();
m_writeSmartPaste = false;
}
diff --git a/webkit/tools/test_shell/mock_webclipboard_impl.h b/webkit/tools/test_shell/mock_webclipboard_impl.h
index 8133089..997596d 100644
--- a/webkit/tools/test_shell/mock_webclipboard_impl.h
+++ b/webkit/tools/test_shell/mock_webclipboard_impl.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// 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.
//
@@ -10,6 +10,9 @@
#ifndef WEBKIT_TOOLS_TEST_SHELL_MOCK_WEBCLIPBOARD_IMPL_H_
#define WEBKIT_TOOLS_TEST_SHELL_MOCK_WEBCLIPBOARD_IMPL_H_
+#include <map>
+
+#include "base/string16.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebClipboard.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebDragData.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebImage.h"
@@ -45,10 +48,12 @@ class MockWebClipboardImpl : public WebKit::WebClipboard {
virtual void writeDataObject(const WebKit::WebDragData& data);
private:
+ void clear();
+
WebKit::WebString m_plainText;
WebKit::WebString m_htmlText;
WebKit::WebImage m_image;
- WebKit::WebVector<WebKit::WebDragData::CustomData> m_customData;
+ std::map<string16, string16> m_customData;
bool m_writeSmartPaste;
};
diff --git a/webkit/tools/test_shell/test_webview_delegate.cc b/webkit/tools/test_shell/test_webview_delegate.cc
index 01c2b68..5baf744 100644
--- a/webkit/tools/test_shell/test_webview_delegate.cc
+++ b/webkit/tools/test_shell/test_webview_delegate.cc
@@ -158,10 +158,13 @@ std::string DescriptionSuitableForTestResult(const std::string& url) {
return url.substr(pos + 1);
}
-// Adds a file called "DRTFakeFile" to |data_object| (CF_HDROP). Use to fake
-// dragging a file.
+// Adds a file called "DRTFakeFile" to |data_object|. Use to fake dragging a
+// file.
void AddDRTFakeFileToDataObject(WebDragData* drag_data) {
- drag_data->appendToFilenames(WebString::fromUTF8("DRTFakeFile"));
+ WebDragData::Item item;
+ item.storageType = WebDragData::Item::StorageTypeFilename;
+ item.filenameData = WebString::fromUTF8("DRTFakeFile");
+ drag_data->addItem(item);
}
// Get a debugging string from a WebNavigationType.