Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "ppapi/cpp/private/flash_clipboard.h" | 5 #include "ppapi/cpp/private/flash_clipboard.h" |
| 6 | 6 |
| 7 #include <vector> | |
| 8 | |
| 7 #include "ppapi/c/pp_bool.h" | 9 #include "ppapi/c/pp_bool.h" |
| 8 #include "ppapi/c/pp_errors.h" | 10 #include "ppapi/c/pp_errors.h" |
| 9 #include "ppapi/cpp/instance.h" | 11 #include "ppapi/cpp/instance.h" |
| 10 #include "ppapi/cpp/module_impl.h" | 12 #include "ppapi/cpp/module_impl.h" |
| 11 #include "ppapi/cpp/var.h" | 13 #include "ppapi/cpp/var.h" |
| 12 | 14 |
| 13 namespace pp { | 15 namespace pp { |
| 14 | 16 |
| 15 namespace { | 17 namespace { |
| 16 | 18 |
| 17 template <> const char* interface_name<PPB_Flash_Clipboard>() { | 19 template <> const char* interface_name<PPB_Flash_Clipboard>() { |
| 18 return PPB_FLASH_CLIPBOARD_INTERFACE; | 20 return PPB_FLASH_CLIPBOARD_INTERFACE; |
| 19 } | 21 } |
| 20 | 22 |
| 23 template <> const char* interface_name<PPB_Flash_Clipboard_3_0>() { | |
| 24 return PPB_FLASH_CLIPBOARD_INTERFACE_3_0; | |
| 25 } | |
| 26 | |
| 21 } // namespace | 27 } // namespace |
| 22 | 28 |
| 23 namespace flash { | 29 namespace flash { |
| 24 | 30 |
| 25 // static | 31 // static |
| 26 bool Clipboard::IsAvailable() { | 32 bool Clipboard::IsAvailable() { |
| 27 return has_interface<PPB_Flash_Clipboard>(); | 33 return has_interface<PPB_Flash_Clipboard>() || |
| 34 has_interface<PPB_Flash_Clipboard_3_0>(); | |
| 28 } | 35 } |
| 29 | 36 |
| 30 // static | 37 // static |
| 31 bool Clipboard::IsFormatAvailable(Instance* instance, | 38 bool Clipboard::IsFormatAvailable(Instance* instance, |
| 32 PP_Flash_Clipboard_Type clipboard_type, | 39 PP_Flash_Clipboard_Type clipboard_type, |
| 33 PP_Flash_Clipboard_Format format) { | 40 PP_Flash_Clipboard_Format format) { |
| 34 bool rv = false; | 41 bool rv = false; |
| 35 if (has_interface<PPB_Flash_Clipboard>()) { | 42 if (has_interface<PPB_Flash_Clipboard>()) { |
| 36 rv = PP_ToBool(get_interface<PPB_Flash_Clipboard>()->IsFormatAvailable( | 43 rv = PP_ToBool(get_interface<PPB_Flash_Clipboard>()->IsFormatAvailable( |
| 37 instance->pp_instance(), clipboard_type, format)); | 44 instance->pp_instance(), clipboard_type, format)); |
| 38 } | 45 } |
| 39 return rv; | 46 return rv; |
| 40 } | 47 } |
| 41 | 48 |
| 42 // static | 49 // static |
| 43 bool Clipboard::ReadPlainText(Instance* instance, | 50 bool Clipboard::ReadData( |
| 44 PP_Flash_Clipboard_Type clipboard_type, | 51 Instance* instance, |
|
dmichael (off chromium)
2012/02/23 18:13:25
brettw's been working on a change to replace Insta
raymes
2012/02/24 07:28:28
Ok
On 2012/02/23 18:13:25, dmichael wrote:
| |
| 45 std::string* text_out) { | 52 PP_Flash_Clipboard_Type clipboard_type, |
| 53 PP_Flash_Clipboard_Format clipboard_format, | |
| 54 PP_Var* out) { | |
| 46 bool rv = false; | 55 bool rv = false; |
| 47 if (has_interface<PPB_Flash_Clipboard>()) { | 56 if (has_interface<PPB_Flash_Clipboard>()) { |
| 48 Var v(Var::PassRef(), | 57 *out = get_interface<PPB_Flash_Clipboard>()->ReadData( |
| 49 get_interface<PPB_Flash_Clipboard>()->ReadPlainText( | 58 instance->pp_instance(), |
| 50 instance->pp_instance(), | 59 clipboard_type, |
| 51 clipboard_type)); | 60 clipboard_format); |
| 52 if (v.is_string()) { | 61 rv = true; |
| 53 rv = true; | 62 } else if (has_interface<PPB_Flash_Clipboard_3_0>() && |
| 54 *text_out = v.AsString(); | 63 clipboard_format == PP_FLASH_CLIPBOARD_FORMAT_PLAINTEXT) { |
| 55 } | 64 *out = get_interface<PPB_Flash_Clipboard_3_0>()->ReadPlainText( |
| 65 instance->pp_instance(), | |
| 66 clipboard_type); | |
|
dmichael (off chromium)
2012/02/23 18:13:25
Do you really need backwards compatibility here? T
raymes
2012/02/24 07:28:28
Spoke to vtl and he says that the backward compat
dmichael (off chromium)
2012/02/24 19:35:44
Okay, vtl understands what you need for Flash more
raymes
2012/02/24 21:38:17
According to vtl, both are needed.
On 2012/02/24 1
| |
| 67 rv = true; | |
| 56 } | 68 } |
| 57 return rv; | 69 return rv; |
| 58 } | 70 } |
| 59 | 71 |
| 60 // static | 72 // static |
| 61 bool Clipboard::WritePlainText(Instance* instance, | 73 bool Clipboard::WriteData( |
| 62 PP_Flash_Clipboard_Type clipboard_type, | 74 Instance* instance, |
| 63 const std::string& text) { | 75 PP_Flash_Clipboard_Type clipboard_type, |
| 76 const std::vector<PP_Flash_Clipboard_Data_Item>& data_items) { | |
| 64 bool rv = false; | 77 bool rv = false; |
| 78 | |
| 65 if (has_interface<PPB_Flash_Clipboard>()) { | 79 if (has_interface<PPB_Flash_Clipboard>()) { |
| 66 rv = (get_interface<PPB_Flash_Clipboard>()->WritePlainText( | 80 new PP_Flash_Clipboard_Data_Item[data_items.size()]; |
|
dmichael (off chromium)
2012/02/23 18:13:25
What is this line doing? Looks like a blatant leak
raymes
2012/02/24 07:28:28
=( undeleted line from an older patchset. Good cat
| |
| 67 instance->pp_instance(), | 81 rv = (get_interface<PPB_Flash_Clipboard>()->WriteData( |
| 68 clipboard_type, | 82 instance->pp_instance(), |
| 69 Var(text).pp_var()) == PP_OK); | 83 clipboard_type, |
| 84 data_items.size(), | |
| 85 &data_items[0]) == PP_OK); | |
|
dmichael (off chromium)
2012/02/23 18:13:25
probably best to return early if data_items.empty(
raymes
2012/02/24 07:28:28
Done.
| |
| 86 } else if (has_interface<PPB_Flash_Clipboard_3_0>()) { | |
| 87 // Take the last plaintext item and write it according to the API. | |
|
dmichael (off chromium)
2012/02/23 18:13:25
I think this backwards-compat part should probably
raymes
2012/02/24 07:28:28
The backward compat code is apparently necessary.
dmichael (off chromium)
2012/02/24 19:35:44
It might be that I don't understand how the clipbo
raymes
2012/02/24 21:38:17
Ah I see what you're saying. The thing is that eac
dmichael (off chromium)
2012/02/24 21:49:36
That makes sense, thanks for explaining. I think a
| |
| 88 for (std::vector<PP_Flash_Clipboard_Data_Item>::const_reverse_iterator | |
| 89 i = data_items.rbegin(); i != data_items.rend(); ++i) { | |
| 90 if (i->format == PP_FLASH_CLIPBOARD_FORMAT_PLAINTEXT) { | |
| 91 rv = (get_interface<PPB_Flash_Clipboard_3_0>()->WritePlainText( | |
| 92 instance->pp_instance(), | |
| 93 clipboard_type, | |
| 94 i->data) == PP_OK); | |
| 95 break; | |
| 96 } | |
| 97 } | |
| 70 } | 98 } |
| 99 | |
| 71 return rv; | 100 return rv; |
| 72 } | 101 } |
| 73 | 102 |
| 74 } // namespace flash | 103 } // namespace flash |
| 75 } // namespace pp | 104 } // namespace pp |
| OLD | NEW |