Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2581)

Unified Diff: content/renderer/pepper/pepper_in_process_resource_creation.cc

Issue 10578043: Hook up content/renderer to the PPAPI host. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: comments addressed Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/renderer/pepper/pepper_in_process_resource_creation.cc
diff --git a/content/renderer/pepper/pepper_in_process_resource_creation.cc b/content/renderer/pepper/pepper_in_process_resource_creation.cc
new file mode 100644
index 0000000000000000000000000000000000000000..39ef3c4198e3e414515af4fbf5d7cde2a7e0287f
--- /dev/null
+++ b/content/renderer/pepper/pepper_in_process_resource_creation.cc
@@ -0,0 +1,143 @@
+// 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.
+
+#include "content/renderer/pepper/pepper_in_process_resource_creation.h"
+
+#include "base/bind.h"
+#include "base/memory/weak_ptr.h"
+#include "base/message_loop.h"
+#include "content/renderer/pepper/content_renderer_pepper_host_factory.h"
+#include "ipc/ipc_message.h"
+#include "ipc/ipc_message_macros.h"
+#include "ppapi/host/ppapi_host.h"
+#include "ppapi/proxy/ppapi_messages.h"
+#include "ppapi/shared_impl/ppapi_globals.h"
+#include "ppapi/shared_impl/resource_tracker.h"
+
+// Note that the code in the creation functions in this file should generally
+// be the same as that in ppapi/proxy/resource_creation_proxy.cc. See
+// pepper_in_process_resource_creation.h for what this file is for.
+
+namespace content {
+
+class PepperInProcessResourceCreation::PluginToHostRouter
+ : public IPC::Sender {
+ public:
+ PluginToHostRouter(RenderViewImpl* render_view,
+ IPC::Sender* host_to_plugin_sender);
+ virtual ~PluginToHostRouter() {}
+
+ // Sender implementation.
+ virtual bool Send(IPC::Message* msg) OVERRIDE;
+
+ private:
+ void DoSend(IPC::Message* msg);
+
+ base::WeakPtrFactory<PluginToHostRouter> weak_factory_;
+
+ ContentRendererPepperHostFactory factory_;
+ ppapi::host::PpapiHost host_;
+
+ DISALLOW_COPY_AND_ASSIGN(PluginToHostRouter);
+};
+
+PepperInProcessResourceCreation::PluginToHostRouter::PluginToHostRouter(
+ RenderViewImpl* render_view,
+ IPC::Sender* host_to_plugin_sender)
+ : weak_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)),
+ factory_(render_view),
+ host_(host_to_plugin_sender, &factory_) {
+}
+
+bool PepperInProcessResourceCreation::PluginToHostRouter::Send(
+ IPC::Message* msg) {
+ // Don't directly call into the message handler to avoid reentrancy. The IPC
+ // systen assumes everything is executed from the message loop, so emulate
+ // the same thing for in-process.
+ MessageLoop::current()->PostTask(FROM_HERE,
+ base::Bind(&PluginToHostRouter::DoSend, weak_factory_.GetWeakPtr(),
+ base::Owned(msg)));
+ return true;
+}
+
+void PepperInProcessResourceCreation::PluginToHostRouter::DoSend(
+ IPC::Message* msg) {
+ host_.OnMessageReceived(*msg);
+}
+
+// HostToPluginRouter ---------------------------------------------------------
+
+class PepperInProcessResourceCreation::HostToPluginRouter
+ : public IPC::Sender {
+ public:
+ HostToPluginRouter();
+ virtual ~HostToPluginRouter() {}
+
+ // Sender implementation.
+ virtual bool Send(IPC::Message* msg) OVERRIDE;
+
+ private:
+ void DispatchMsg(IPC::Message* msg);
+
+ void OnMsgResourceReply(
+ const ppapi::proxy::ResourceMessageReplyParams& reply_params,
+ const IPC::Message& nested_msg);
+
+ base::WeakPtrFactory<HostToPluginRouter> weak_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(HostToPluginRouter);
+};
+
+PepperInProcessResourceCreation::HostToPluginRouter::HostToPluginRouter()
+ : weak_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) {
+}
+
+bool PepperInProcessResourceCreation::HostToPluginRouter::Send(
+ IPC::Message* msg) {
+ // As in the PluginToHostRouter, dispatch from the message loop.
+ MessageLoop::current()->PostTask(FROM_HERE,
+ base::Bind(&HostToPluginRouter::DispatchMsg,
+ weak_factory_.GetWeakPtr(),
+ base::Owned(msg)));
+ return true;
+}
+
+void PepperInProcessResourceCreation::HostToPluginRouter::DispatchMsg(
+ IPC::Message* msg) {
+ // Emulate the proxy by dispatching the relevant message here.
+ IPC_BEGIN_MESSAGE_MAP(HostToPluginRouter, *msg)
+ IPC_MESSAGE_HANDLER(PpapiPluginMsg_ResourceReply, OnMsgResourceReply)
+ IPC_END_MESSAGE_MAP()
+}
+
+void PepperInProcessResourceCreation::HostToPluginRouter::OnMsgResourceReply(
+ const ppapi::proxy::ResourceMessageReplyParams& reply_params,
+ const IPC::Message& nested_msg) {
+ ppapi::Resource* resource =
+ ppapi::PpapiGlobals::Get()->GetResourceTracker()->GetResource(
+ reply_params.pp_resource());
+ if (!resource) {
+ // The resource could have been destroyed while the async processing was
+ // pending. Just drop the message.
+ return;
+ }
+ resource->OnReplyReceived(reply_params.sequence(), reply_params.result(),
+ nested_msg);
+}
+
+// PepperInProcessResourceCreation --------------------------------------------
+
+PepperInProcessResourceCreation::PepperInProcessResourceCreation(
+ RenderViewImpl* render_view,
+ webkit::ppapi::PluginInstance* instance)
+ : ResourceCreationImpl(instance),
+ host_to_plugin_router_(new HostToPluginRouter),
+ plugin_to_host_router_(
+ new PluginToHostRouter(render_view, host_to_plugin_router_.get())) {
+}
+
+PepperInProcessResourceCreation::~PepperInProcessResourceCreation() {
+}
+
+} // namespace content
« no previous file with comments | « content/renderer/pepper/pepper_in_process_resource_creation.h ('k') | content/renderer/pepper/pepper_plugin_delegate_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698