| Index: ppapi/proxy/ppb_image_data_proxy.cc
|
| diff --git a/ppapi/proxy/ppb_image_data_proxy.cc b/ppapi/proxy/ppb_image_data_proxy.cc
|
| index 32c24a942314f11ceb2415dcad0faac491cc9b05..20f8f62069b453dc211c70eb2e6dc2a85c59ddc9 100644
|
| --- a/ppapi/proxy/ppb_image_data_proxy.cc
|
| +++ b/ppapi/proxy/ppb_image_data_proxy.cc
|
| @@ -18,6 +18,7 @@
|
| #include "ppapi/proxy/ppapi_messages.h"
|
| #include "ppapi/shared_impl/host_resource.h"
|
| #include "ppapi/shared_impl/resource.h"
|
| +#include "ppapi/thunk/enter.h"
|
| #include "ppapi/thunk/thunk.h"
|
| #include "skia/ext/platform_canvas.h"
|
| #include "ui/gfx/surface/transport_dib.h"
|
| @@ -94,5 +95,88 @@ ImageHandle ImageData::HandleFromInt(int32_t i) {
|
| #endif
|
| }
|
|
|
| +PPB_ImageData_Proxy::PPB_ImageData_Proxy(Dispatcher* dispatcher)
|
| + : InterfaceProxy(dispatcher) {
|
| +}
|
| +
|
| +PPB_ImageData_Proxy::~PPB_ImageData_Proxy() {
|
| +}
|
| +
|
| +// static
|
| +PP_Resource PPB_ImageData_Proxy::CreateProxyResource(PP_Instance instance,
|
| + PP_ImageDataFormat format,
|
| + const PP_Size& size,
|
| + PP_Bool init_to_zero) {
|
| + PluginDispatcher* dispatcher = PluginDispatcher::GetForInstance(instance);
|
| + if (!dispatcher)
|
| + return 0;
|
| +
|
| + HostResource result;
|
| + std::string image_data_desc;
|
| + ImageHandle image_handle = ImageData::NullHandle;
|
| + dispatcher->Send(new PpapiHostMsg_PPBImageData_Create(
|
| + kApiID, instance, format, size, init_to_zero,
|
| + &result, &image_data_desc, &image_handle));
|
| +
|
| + if (result.is_null() || image_data_desc.size() != sizeof(PP_ImageDataDesc))
|
| + return 0;
|
| +
|
| + // We serialize the PP_ImageDataDesc just by copying to a string.
|
| + PP_ImageDataDesc desc;
|
| + memcpy(&desc, image_data_desc.data(), sizeof(PP_ImageDataDesc));
|
| +
|
| + return (new ImageData(result, desc, image_handle))->GetReference();
|
| +}
|
| +
|
| +bool PPB_ImageData_Proxy::OnMessageReceived(const IPC::Message& msg) {
|
| + bool handled = true;
|
| + IPC_BEGIN_MESSAGE_MAP(PPB_ImageData_Proxy, msg)
|
| + IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBImageData_Create, OnHostMsgCreate)
|
| + IPC_MESSAGE_UNHANDLED(handled = false)
|
| + IPC_END_MESSAGE_MAP()
|
| + return handled;
|
| +}
|
| +
|
| +void PPB_ImageData_Proxy::OnHostMsgCreate(PP_Instance instance,
|
| + int32_t format,
|
| + const PP_Size& size,
|
| + PP_Bool init_to_zero,
|
| + HostResource* result,
|
| + std::string* image_data_desc,
|
| + ImageHandle* result_image_handle) {
|
| + *result_image_handle = ImageData::NullHandle;
|
| +
|
| + thunk::EnterResourceCreation enter(instance);
|
| + if (enter.failed())
|
| + return;
|
| +
|
| + PP_Resource resource = enter.functions()->CreateImageData(
|
| + instance, static_cast<PP_ImageDataFormat>(format), size, init_to_zero);
|
| + if (!resource)
|
| + return;
|
| + result->SetHostResource(instance, resource);
|
| +
|
| + // Get the description, it's just serialized as a string.
|
| + thunk::EnterResourceNoLock<thunk::PPB_ImageData_API> enter_resource(
|
| + resource, false);
|
| + PP_ImageDataDesc desc;
|
| + if (enter_resource.object()->Describe(&desc) == PP_TRUE) {
|
| + image_data_desc->resize(sizeof(PP_ImageDataDesc));
|
| + memcpy(&(*image_data_desc)[0], &desc, sizeof(PP_ImageDataDesc));
|
| + }
|
| +
|
| + // Get the shared memory handle.
|
| + uint32_t byte_count = 0;
|
| + int32_t handle = 0;
|
| + if (enter_resource.object()->GetSharedMemory(&handle, &byte_count) == PP_OK) {
|
| +#if defined(OS_WIN)
|
| + ImageHandle ih = ImageData::HandleFromInt(handle);
|
| + *result_image_handle = dispatcher()->ShareHandleWithRemote(ih, false);
|
| +#else
|
| + *result_image_handle = ImageData::HandleFromInt(handle);
|
| +#endif
|
| + }
|
| +}
|
| +
|
| } // namespace proxy
|
| } // namespace ppapi
|
|
|