Index: third_party/WebKit/Source/core/clipboard/DataTransfer.cpp |
diff --git a/third_party/WebKit/Source/core/clipboard/DataTransfer.cpp b/third_party/WebKit/Source/core/clipboard/DataTransfer.cpp |
index 2738516710bd335ed2df5c41eca8df85e30a864e..1cee0fbc7652f4441c288f15429a48c2ce0478cd 100644 |
--- a/third_party/WebKit/Source/core/clipboard/DataTransfer.cpp |
+++ b/third_party/WebKit/Source/core/clipboard/DataTransfer.cpp |
@@ -192,12 +192,20 @@ void DataTransfer::setData(const String& type, const String& data) { |
data_object_->SetData(NormalizeType(type), data); |
} |
-// extensions beyond IE's API |
-Vector<String> DataTransfer::types() const { |
+bool DataTransfer::hasDataStoreItemListChanged() const { |
+ return data_store_item_list_changed_ || !CanReadTypes(); |
+} |
+ |
+void DataTransfer::OnItemListChanged() { |
+ data_store_item_list_changed_ = true; |
+} |
+ |
+Vector<String> DataTransfer::types() { |
Vector<String> types; |
if (!CanReadTypes()) |
return types; |
jsbell
2017/05/15 20:49:28
Not new in this CL, but how about `return Vector<S
Raphael Kubo da Costa (rakuco)
2017/05/16 08:51:51
Done.
|
+ data_store_item_list_changed_ = false; |
return data_object_->Types(); |
} |
@@ -429,7 +437,10 @@ DataTransfer::DataTransfer(DataTransferType type, |
drop_effect_("uninitialized"), |
effect_allowed_("uninitialized"), |
transfer_type_(type), |
- data_object_(data_object) {} |
+ data_object_(data_object), |
+ data_store_item_list_changed_(true) { |
+ data_object_->AddObserver(this); |
+} |
void DataTransfer::setDragImage(ImageResourceContent* image, |
Node* node, |
@@ -461,7 +472,7 @@ bool DataTransfer::HasStringOfType(const String& type) const { |
if (!CanReadTypes()) |
return false; |
- return types().Contains(type); |
+ return data_object_->Types().Contains(type); |
} |
DragOperation ConvertDropZoneOperationToDragOperation( |