Chromium Code Reviews| Index: ppapi/proxy/ppb_flash_clipboard_proxy.cc |
| diff --git a/ppapi/proxy/ppb_flash_clipboard_proxy.cc b/ppapi/proxy/ppb_flash_clipboard_proxy.cc |
| index df6cc59946bce0775b9360c94a93e88854280a95..1d1965da9509a0c2254ceb5cb21843aa42f26c93 100644 |
| --- a/ppapi/proxy/ppb_flash_clipboard_proxy.cc |
| +++ b/ppapi/proxy/ppb_flash_clipboard_proxy.cc |
| @@ -62,32 +62,59 @@ PP_Bool PPB_Flash_Clipboard_Proxy::IsFormatAvailable( |
| &result)); |
| return PP_FromBool(result); |
| } |
| - |
| -PP_Var PPB_Flash_Clipboard_Proxy::ReadPlainText( |
| +PP_Var PPB_Flash_Clipboard_Proxy::ReadData( |
| PP_Instance instance, |
| - PP_Flash_Clipboard_Type clipboard_type) { |
| - if (!IsValidClipboardType(clipboard_type)) |
| + PP_Flash_Clipboard_Type clipboard_type, |
| + PP_Flash_Clipboard_Format format) { |
| + if (!IsValidClipboardType(clipboard_type) || !IsValidClipboardFormat(format)) |
| return PP_MakeUndefined(); |
| ReceiveSerializedVarReturnValue result; |
| - dispatcher()->Send(new PpapiHostMsg_PPBFlashClipboard_ReadPlainText( |
| + dispatcher()->Send(new PpapiHostMsg_PPBFlashClipboard_ReadData( |
| API_ID_PPB_FLASH_CLIPBOARD, instance, |
| - static_cast<int>(clipboard_type), &result)); |
| + static_cast<int>(clipboard_type), static_cast<int>(format), &result)); |
| return result.Return(dispatcher()); |
| } |
| -int32_t PPB_Flash_Clipboard_Proxy::WritePlainText( |
| + |
| +int32_t PPB_Flash_Clipboard_Proxy::WriteData( |
| PP_Instance instance, |
| PP_Flash_Clipboard_Type clipboard_type, |
| - const PP_Var& text) { |
| + uint32_t data_item_count, |
| + const struct |
| + PP_Flash_Clipboard_Data_Item data_items[]) { |
|
dmichael (off chromium)
2012/02/23 18:13:25
nit: shouldn't this be on line 84?
raymes
2012/02/24 07:28:28
Done.
|
| if (!IsValidClipboardType(clipboard_type)) |
| return PP_ERROR_BADARGUMENT; |
| - dispatcher()->Send(new PpapiHostMsg_PPBFlashClipboard_WritePlainText( |
| + // Convert the array of PP_Flash_Clipboard_Data_Item into two parallel |
| + // arrays of format and corresponding data. |
| + scoped_array<PP_Var> formats(new PP_Var[data_item_count]); |
| + scoped_array<PP_Var> data(new PP_Var[data_item_count]); |
| + |
| + for (uint32_t i = 0; i < data_item_count; ++i) { |
| + formats[i] = PP_MakeInt32(data_items[i].format); |
|
dmichael (off chromium)
2012/02/23 18:13:25
Can't you just send a vector of int32? Why turn th
raymes
2012/02/24 07:28:28
Ah I didn't know about this. Done.
On 2012/02/23
|
| + data[i] = data_items[i].data; |
| + } |
| + |
| + std::vector<SerializedVar> formats_converted; |
| + std::vector<SerializedVar> data_converted; |
| + SerializedVarSendInput::ConvertVector( |
| + dispatcher(), |
| + formats.get(), |
| + data_item_count, |
| + &formats_converted); |
| + SerializedVarSendInput::ConvertVector( |
| + dispatcher(), |
| + data.get(), |
| + data_item_count, |
| + &data_converted); |
| + |
| + dispatcher()->Send(new PpapiHostMsg_PPBFlashClipboard_WriteData( |
| API_ID_PPB_FLASH_CLIPBOARD, |
| instance, |
| static_cast<int>(clipboard_type), |
| - SerializedVarSendInput(dispatcher(), text))); |
| + formats_converted, |
| + data_converted)); |
| // Assume success, since it allows us to avoid a sync IPC. |
| return PP_OK; |
| } |
| @@ -97,10 +124,10 @@ bool PPB_Flash_Clipboard_Proxy::OnMessageReceived(const IPC::Message& msg) { |
| IPC_BEGIN_MESSAGE_MAP(PPB_Flash_Clipboard_Proxy, msg) |
| IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBFlashClipboard_IsFormatAvailable, |
| OnMsgIsFormatAvailable) |
| - IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBFlashClipboard_ReadPlainText, |
| - OnMsgReadPlainText) |
| - IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBFlashClipboard_WritePlainText, |
| - OnMsgWritePlainText) |
| + IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBFlashClipboard_ReadData, |
| + OnMsgReadData) |
| + IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBFlashClipboard_WriteData, |
| + OnMsgWriteData) |
| IPC_MESSAGE_UNHANDLED(handled = false) |
| IPC_END_MESSAGE_MAP() |
| return handled; |
| @@ -122,29 +149,50 @@ void PPB_Flash_Clipboard_Proxy::OnMsgIsFormatAvailable( |
| } |
| } |
| -void PPB_Flash_Clipboard_Proxy::OnMsgReadPlainText( |
| +void PPB_Flash_Clipboard_Proxy::OnMsgReadData( |
| PP_Instance instance, |
| int clipboard_type, |
| + int format, |
| SerializedVarReturnValue result) { |
| EnterFlashClipboardNoLock enter(instance, true); |
| if (enter.succeeded()) { |
| result.Return(dispatcher(), |
| - enter.functions()->ReadPlainText( |
| + enter.functions()->ReadData( |
| instance, |
| - static_cast<PP_Flash_Clipboard_Type>(clipboard_type))); |
| + static_cast<PP_Flash_Clipboard_Type>(clipboard_type), |
| + static_cast<PP_Flash_Clipboard_Format>(format))); |
| } |
| } |
| -void PPB_Flash_Clipboard_Proxy::OnMsgWritePlainText( |
| +void PPB_Flash_Clipboard_Proxy::OnMsgWriteData( |
| PP_Instance instance, |
| int clipboard_type, |
| - SerializedVarReceiveInput text) { |
| + SerializedVarVectorReceiveInput formats_vector, |
| + SerializedVarVectorReceiveInput data_vector) { |
| EnterFlashClipboardNoLock enter(instance, true); |
| if (enter.succeeded()) { |
| - int32_t result = enter.functions()->WritePlainText( |
| + // Convert parallel arrays of PP_Var into an array of |
| + // PP_Flash_Clipboard_Data_Item structs. |
| + uint32_t formats_size; |
| + uint32_t data_size; |
| + PP_Var* formats = formats_vector.Get(dispatcher(), &formats_size); |
| + PP_Var* data = data_vector.Get(dispatcher(), &data_size); |
| + CHECK(formats_size == data_size); |
| + |
| + scoped_array<PP_Flash_Clipboard_Data_Item> data_items( |
| + new PP_Flash_Clipboard_Data_Item[formats_size]); |
| + |
| + for (uint32_t i = 0; i < formats_size; ++i) { |
| + data_items[i].format = |
| + static_cast<PP_Flash_Clipboard_Format>(formats[i].value.as_int); |
| + data_items[i].data = data[i]; |
| + } |
| + |
| + int32_t result = enter.functions()->WriteData( |
| instance, |
| static_cast<PP_Flash_Clipboard_Type>(clipboard_type), |
| - text.Get(dispatcher())); |
| + data_size, |
| + data_items.get()); |
| DLOG_IF(WARNING, result != PP_OK) |
| << "Write to clipboard failed unexpectedly."; |
| (void)result; // Prevent warning in release mode. |