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

Side by Side Diff: content/renderer/pepper/ppb_tcp_server_socket_private_impl.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 tcp tests 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 (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 "content/renderer/pepper/ppb_tcp_server_socket_private_impl.h" 5 #include "content/renderer/pepper/ppb_tcp_server_socket_private_impl.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "content/renderer/pepper/host_globals.h" 8 #include "content/renderer/pepper/host_globals.h"
9 #include "content/renderer/pepper/pepper_helper_impl.h" 9 #include "content/renderer/pepper/pepper_helper_impl.h"
10 #include "content/renderer/pepper/pepper_plugin_instance_impl.h"
10 #include "content/renderer/pepper/ppb_tcp_socket_private_impl.h" 11 #include "content/renderer/pepper/ppb_tcp_socket_private_impl.h"
11 #include "content/renderer/pepper/resource_helper.h" 12 #include "content/renderer/render_thread_impl.h"
12 #include "ppapi/proxy/ppapi_messages.h" 13 #include "ppapi/proxy/ppapi_messages.h"
14 #include "ppapi/thunk/enter.h"
13 15
14 namespace content { 16 namespace content {
15 17
16 PPB_TCPServerSocket_Private_Impl::PPB_TCPServerSocket_Private_Impl( 18 PPB_TCPServerSocket_Private_Impl::PPB_TCPServerSocket_Private_Impl(
17 PP_Instance instance) 19 PP_Instance instance)
18 : ::ppapi::PPB_TCPServerSocket_Shared(instance) { 20 : ::ppapi::PPB_TCPServerSocket_Shared(instance),
21 routing_id_(RenderThreadImpl::current()->GenerateRoutingID()) {
22 ChildThread::current()->AddRoute(routing_id_, this);
19 } 23 }
20 24
21 PPB_TCPServerSocket_Private_Impl::~PPB_TCPServerSocket_Private_Impl() { 25 PPB_TCPServerSocket_Private_Impl::~PPB_TCPServerSocket_Private_Impl() {
22 StopListening(); 26 StopListening();
27 ChildThread::current()->RemoveRoute(routing_id_);
23 } 28 }
24 29
25 PP_Resource PPB_TCPServerSocket_Private_Impl::CreateResource( 30 PP_Resource PPB_TCPServerSocket_Private_Impl::CreateResource(
26 PP_Instance instance) { 31 PP_Instance instance) {
27 PPB_TCPServerSocket_Private_Impl* socket = 32 PPB_TCPServerSocket_Private_Impl* socket =
28 new PPB_TCPServerSocket_Private_Impl(instance); 33 new PPB_TCPServerSocket_Private_Impl(instance);
29 return socket->GetReference(); 34 return socket->GetReference();
30 } 35 }
31 36
32 void PPB_TCPServerSocket_Private_Impl::OnAcceptCompleted( 37 void PPB_TCPServerSocket_Private_Impl::SendListen(
33 bool succeeded, 38 const PP_NetAddress_Private& addr,
39 int32_t backlog) {
40 RenderThreadImpl::current()->Send(new PpapiHostMsg_PPBTCPServerSocket_Listen(
41 routing_id_, 0, pp_resource(), addr, backlog));
42 }
43
44 void PPB_TCPServerSocket_Private_Impl::SendAccept() {
45 int new_socket_routing_id = RenderThreadImpl::current()->GenerateRoutingID();
46 RenderThreadImpl::current()->Send(new PpapiHostMsg_PPBTCPServerSocket_Accept(
47 new_socket_routing_id, socket_id_));
48 }
49
50 void PPB_TCPServerSocket_Private_Impl::SendStopListening() {
51 if (socket_id_ != 0) {
52 RenderThreadImpl::current()->Send(
53 new PpapiHostMsg_PPBTCPServerSocket_Destroy(socket_id_));
54 }
55 }
56
57 bool PPB_TCPServerSocket_Private_Impl::OnMessageReceived(
58 const IPC::Message& message) {
59 bool handled = true;
60 IPC_BEGIN_MESSAGE_MAP(PPB_TCPServerSocket_Private_Impl, message)
61 IPC_MESSAGE_HANDLER(PpapiMsg_PPBTCPServerSocket_ListenACK,
62 OnTCPServerSocketListenACK)
63 IPC_MESSAGE_HANDLER(PpapiMsg_PPBTCPServerSocket_AcceptACK,
64 OnTCPServerSocketAcceptACK)
65 IPC_MESSAGE_UNHANDLED(handled = false)
66 IPC_END_MESSAGE_MAP()
67 return handled;
68 }
69
70 void PPB_TCPServerSocket_Private_Impl::OnTCPServerSocketListenACK(
71 uint32 plugin_dispatcher_id,
72 PP_Resource socket_resource,
73 uint32 socket_id,
74 const PP_NetAddress_Private& local_addr,
75 int32_t status) {
76 ppapi::thunk::EnterResource<ppapi::thunk::PPB_TCPServerSocket_Private_API>
77 enter(socket_resource, true);
78 if (enter.succeeded()) {
79 OnListenCompleted(socket_id, local_addr, status);
80 } else if (socket_id != 0 && status == PP_OK) {
81 // StopListening was called before completion of Listen.
82 RenderThreadImpl::current()->Send(
83 new PpapiHostMsg_PPBTCPServerSocket_Destroy(socket_id));
84 }
85 }
86
87 void PPB_TCPServerSocket_Private_Impl::OnTCPServerSocketAcceptACK(
88 int32 socket_routing_id,
89 uint32 socket_id,
34 uint32 accepted_socket_id, 90 uint32 accepted_socket_id,
35 const PP_NetAddress_Private& local_addr, 91 const PP_NetAddress_Private& local_addr,
36 const PP_NetAddress_Private& remote_addr) { 92 const PP_NetAddress_Private& remote_addr) {
93 bool succeeded = (accepted_socket_id != 0);
37 if (!::ppapi::TrackedCallback::IsPending(accept_callback_) || 94 if (!::ppapi::TrackedCallback::IsPending(accept_callback_) ||
38 !tcp_socket_buffer_) { 95 !tcp_socket_buffer_) {
39 NOTREACHED(); 96 NOTREACHED();
40 return; 97 return;
41 } 98 }
42 99
43 if (succeeded) { 100 if (succeeded) {
44 *tcp_socket_buffer_ = 101 *tcp_socket_buffer_ =
45 PPB_TCPSocket_Private_Impl::CreateConnectedSocket(pp_instance(), 102 PPB_TCPSocket_Private_Impl::CreateConnectedSocket(pp_instance(),
103 socket_routing_id,
46 accepted_socket_id, 104 accepted_socket_id,
47 local_addr, 105 local_addr,
48 remote_addr); 106 remote_addr);
49 } 107 }
50 tcp_socket_buffer_ = NULL; 108 tcp_socket_buffer_ = NULL;
51 109
52 accept_callback_->Run(succeeded ? PP_OK : PP_ERROR_FAILED); 110 accept_callback_->Run(succeeded ? PP_OK : PP_ERROR_FAILED);
53 } 111 }
54 112
55 void PPB_TCPServerSocket_Private_Impl::SendListen(
56 const PP_NetAddress_Private& addr,
57 int32_t backlog) {
58 PepperHelperImpl* helper = GetHelper();
59 if (!helper)
60 return;
61
62 helper->Send(new PpapiHostMsg_PPBTCPServerSocket_Listen(
63 helper->routing_id(), 0, pp_resource(), addr, backlog));
64 }
65
66 void PPB_TCPServerSocket_Private_Impl::SendAccept() {
67 PepperHelperImpl* helper = GetHelper();
68 if (!helper)
69 return;
70
71 helper->Send(new PpapiHostMsg_PPBTCPServerSocket_Accept(
72 helper->routing_id(), socket_id_));
73 }
74
75 void PPB_TCPServerSocket_Private_Impl::SendStopListening() {
76 PepperHelperImpl* helper = GetHelper();
77 if (!helper)
78 return;
79
80 if (socket_id_ != 0) {
81 helper->Send(new PpapiHostMsg_PPBTCPServerSocket_Destroy(
82 socket_id_));
83 helper->TCPServerSocketStopListening(socket_id_);
84 }
85 }
86
87 PepperHelperImpl* PPB_TCPServerSocket_Private_Impl::GetHelper() {
88 return ResourceHelper::GetHelper(this);
89 }
90
91 } // namespace content 113 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698