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

Side by Side Diff: content/renderer/pepper/pepper_browser_connection.cc

Issue 20777009: A few more cleanups to the pepper code. Dispatch IPCs in the sockets implementations directly by ha… (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: fix browsertest Created 7 years, 4 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "content/renderer/pepper/pepper_browser_connection.h" 5 #include "content/renderer/pepper/pepper_browser_connection.h"
6 6
7 #include <limits> 7 #include <limits>
8 8
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "content/common/view_messages.h" 10 #include "content/common/view_messages.h"
11 #include "content/renderer/pepper/pepper_helper_impl.h" 11 #include "content/renderer/pepper/pepper_helper_impl.h"
12 #include "content/renderer/pepper/pepper_in_process_router.h" 12 #include "content/renderer/pepper/pepper_in_process_router.h"
13 #include "content/renderer/render_view_impl.h" 13 #include "content/renderer/render_view_impl.h"
14 #include "ipc/ipc_message_macros.h" 14 #include "ipc/ipc_message_macros.h"
15 #include "ppapi/proxy/ppapi_messages.h" 15 #include "ppapi/proxy/ppapi_messages.h"
16 #include "ppapi/proxy/resource_message_params.h" 16 #include "ppapi/proxy/resource_message_params.h"
17 17
18 namespace content { 18 namespace content {
19 19
20 PepperBrowserConnection::PepperBrowserConnection(PepperHelperImpl* helper) 20 PepperBrowserConnection::PepperBrowserConnection(RenderView* render_view)
21 : helper_(helper), 21 : RenderViewObserver(render_view),
22 RenderViewObserverTracker<PepperBrowserConnection>(render_view),
22 next_sequence_number_(1) { 23 next_sequence_number_(1) {
23 } 24 }
24 25
25 PepperBrowserConnection::~PepperBrowserConnection() { 26 PepperBrowserConnection::~PepperBrowserConnection() {
26 } 27 }
27 28
28 bool PepperBrowserConnection::OnMessageReceived(const IPC::Message& msg) { 29 bool PepperBrowserConnection::OnMessageReceived(const IPC::Message& msg) {
29 // Check if the message is an in-process reply. 30 // Check if the message is an in-process reply.
30 if (PepperInProcessRouter::OnPluginMsgReceived(msg)) 31 if (PepperInProcessRouter::OnPluginMsgReceived(msg))
31 return true; 32 return true;
32 33
33 bool handled = true; 34 bool handled = true;
34 IPC_BEGIN_MESSAGE_MAP(PepperBrowserConnection, msg) 35 IPC_BEGIN_MESSAGE_MAP(PepperBrowserConnection, msg)
35 IPC_MESSAGE_HANDLER(PpapiHostMsg_CreateResourceHostFromHostReply, 36 IPC_MESSAGE_HANDLER(PpapiHostMsg_CreateResourceHostFromHostReply,
36 OnMsgCreateResourceHostFromHostReply) 37 OnMsgCreateResourceHostFromHostReply)
37 IPC_MESSAGE_UNHANDLED(handled = false) 38 IPC_MESSAGE_UNHANDLED(handled = false)
38 IPC_END_MESSAGE_MAP() 39 IPC_END_MESSAGE_MAP()
39 40
40 return handled; 41 return handled;
41 } 42 }
42 43
43 void PepperBrowserConnection::DidCreateInProcessInstance( 44 void PepperBrowserConnection::DidCreateInProcessInstance(
44 PP_Instance instance, 45 PP_Instance instance,
45 int render_view_id, 46 int render_view_id,
46 const GURL& document_url, 47 const GURL& document_url,
47 const GURL& plugin_url) { 48 const GURL& plugin_url) {
48 helper_->render_view()->Send( 49 Send(new ViewHostMsg_DidCreateInProcessInstance(
49 new ViewHostMsg_DidCreateInProcessInstance( 50 instance,
50 instance, 51 // Browser provides the render process id.
51 // Browser provides the render process id. 52 PepperRendererInstanceData(0,
52 PepperRendererInstanceData(0, 53 render_view_id,
53 render_view_id, 54 document_url,
54 document_url, 55 plugin_url)));
55 plugin_url)));
56 } 56 }
57 57
58 void PepperBrowserConnection::DidDeleteInProcessInstance(PP_Instance instance) { 58 void PepperBrowserConnection::DidDeleteInProcessInstance(PP_Instance instance) {
59 helper_->render_view()->Send( 59 Send(new ViewHostMsg_DidDeleteInProcessInstance(instance));
60 new ViewHostMsg_DidDeleteInProcessInstance(instance));
61 } 60 }
62 61
63 void PepperBrowserConnection::SendBrowserCreate( 62 void PepperBrowserConnection::SendBrowserCreate(
64 int child_process_id, 63 int child_process_id,
65 PP_Instance instance, 64 PP_Instance instance,
66 const IPC::Message& nested_msg, 65 const IPC::Message& nested_msg,
67 const PendingResourceIDCallback& callback) { 66 const PendingResourceIDCallback& callback) {
68 int32_t sequence_number = GetNextSequence(); 67 int32_t sequence_number = GetNextSequence();
69 pending_create_map_[sequence_number] = callback; 68 pending_create_map_[sequence_number] = callback;
70 ppapi::proxy::ResourceMessageCallParams params(0, sequence_number); 69 ppapi::proxy::ResourceMessageCallParams params(0, sequence_number);
71 helper_->Send(new PpapiHostMsg_CreateResourceHostFromHost( 70 Send(new PpapiHostMsg_CreateResourceHostFromHost(
72 helper_->routing_id(), 71 routing_id(),
73 child_process_id, 72 child_process_id,
74 params, 73 params,
75 instance, 74 instance,
76 nested_msg)); 75 nested_msg));
77 } 76 }
78 77
79 void PepperBrowserConnection::SendBrowserFileRefGetInfo( 78 void PepperBrowserConnection::SendBrowserFileRefGetInfo(
80 int child_process_id, 79 int child_process_id,
81 const std::vector<PP_Resource>& resources, 80 const std::vector<PP_Resource>& resources,
82 const FileRefGetInfoCallback& callback) { 81 const FileRefGetInfoCallback& callback) {
83 int32_t sequence_number = GetNextSequence(); 82 int32_t sequence_number = GetNextSequence();
84 get_info_map_[sequence_number] = callback; 83 get_info_map_[sequence_number] = callback;
85 helper_->Send(new PpapiHostMsg_FileRef_GetInfoForRenderer( 84 Send(new PpapiHostMsg_FileRef_GetInfoForRenderer(
86 helper_->routing_id(), child_process_id, sequence_number, resources)); 85 routing_id(), child_process_id, sequence_number, resources));
87 } 86 }
88 87
89 void PepperBrowserConnection::OnMsgCreateResourceHostFromHostReply( 88 void PepperBrowserConnection::OnMsgCreateResourceHostFromHostReply(
90 int32_t sequence_number, 89 int32_t sequence_number,
91 int pending_resource_host_id) { 90 int pending_resource_host_id) {
92 // Check that the message is destined for the plugin this object is associated 91 // Check that the message is destined for the plugin this object is associated
93 // with. 92 // with.
94 std::map<int32_t, PendingResourceIDCallback>::iterator it = 93 std::map<int32_t, PendingResourceIDCallback>::iterator it =
95 pending_create_map_.find(sequence_number); 94 pending_create_map_.find(sequence_number);
96 if (it != pending_create_map_.end()) { 95 if (it != pending_create_map_.end()) {
(...skipping 29 matching lines...) Expand all
126 // manually check. 125 // manually check.
127 int32_t ret = next_sequence_number_; 126 int32_t ret = next_sequence_number_;
128 if (next_sequence_number_ == std::numeric_limits<int32_t>::max()) 127 if (next_sequence_number_ == std::numeric_limits<int32_t>::max())
129 next_sequence_number_ = 1; // Skip 0 which is invalid. 128 next_sequence_number_ = 1; // Skip 0 which is invalid.
130 else 129 else
131 next_sequence_number_++; 130 next_sequence_number_++;
132 return ret; 131 return ret;
133 } 132 }
134 133
135 } // namespace content 134 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/pepper/pepper_browser_connection.h ('k') | content/renderer/pepper/pepper_file_io_host.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698