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

Side by Side Diff: ppapi/proxy/ppp_messaging_proxy.cc

Issue 113263003: Pepper: More interface_list cleanup. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years 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
« no previous file with comments | « ppapi/proxy/ppp_messaging_proxy.h ('k') | ppapi/proxy/ppp_mouse_lock_proxy.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "ppapi/proxy/ppp_messaging_proxy.h" 5 #include "ppapi/proxy/ppp_messaging_proxy.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "ppapi/c/ppp_messaging.h" 9 #include "ppapi/c/ppp_messaging.h"
10 #include "ppapi/proxy/host_dispatcher.h" 10 #include "ppapi/proxy/host_dispatcher.h"
(...skipping 27 matching lines...) Expand all
38 } 38 }
39 39
40 static const PPP_Messaging messaging_interface = { 40 static const PPP_Messaging messaging_interface = {
41 &HandleMessage 41 &HandleMessage
42 }; 42 };
43 #else 43 #else
44 // The NaCl plugin doesn't need the host side interface - stub it out. 44 // The NaCl plugin doesn't need the host side interface - stub it out.
45 static const PPP_Messaging messaging_interface = {}; 45 static const PPP_Messaging messaging_interface = {};
46 #endif // !defined(OS_NACL) 46 #endif // !defined(OS_NACL)
47 47
48 InterfaceProxy* CreateMessagingProxy(Dispatcher* dispatcher) {
49 return new PPP_Messaging_Proxy(dispatcher);
50 }
51
52 } // namespace 48 } // namespace
53 49
54 PPP_Messaging_Proxy::PPP_Messaging_Proxy(Dispatcher* dispatcher) 50 PPP_Messaging_Proxy::PPP_Messaging_Proxy(Dispatcher* dispatcher)
55 : InterfaceProxy(dispatcher), 51 : InterfaceProxy(dispatcher),
56 ppp_messaging_impl_(NULL) { 52 ppp_messaging_impl_(NULL) {
57 if (dispatcher->IsPlugin()) { 53 if (dispatcher->IsPlugin()) {
58 ppp_messaging_impl_ = static_cast<const PPP_Messaging*>( 54 ppp_messaging_impl_ = static_cast<const PPP_Messaging*>(
59 dispatcher->local_get_interface()(PPP_MESSAGING_INTERFACE)); 55 dispatcher->local_get_interface()(PPP_MESSAGING_INTERFACE));
60 } 56 }
61 } 57 }
62 58
63 PPP_Messaging_Proxy::~PPP_Messaging_Proxy() { 59 PPP_Messaging_Proxy::~PPP_Messaging_Proxy() {
64 } 60 }
65 61
66 // static 62 // static
67 const InterfaceProxy::Info* PPP_Messaging_Proxy::GetInfo() { 63 const PPP_Messaging* PPP_Messaging_Proxy::GetProxyInterface() {
68 static const Info info = { 64 return &messaging_interface;
69 &messaging_interface,
70 PPP_MESSAGING_INTERFACE,
71 API_ID_PPP_MESSAGING,
72 false,
73 &CreateMessagingProxy,
74 };
75 return &info;
76 } 65 }
77 66
78 bool PPP_Messaging_Proxy::OnMessageReceived(const IPC::Message& msg) { 67 bool PPP_Messaging_Proxy::OnMessageReceived(const IPC::Message& msg) {
79 if (!dispatcher()->IsPlugin()) 68 if (!dispatcher()->IsPlugin())
80 return false; 69 return false;
81 70
82 bool handled = true; 71 bool handled = true;
83 IPC_BEGIN_MESSAGE_MAP(PPP_Messaging_Proxy, msg) 72 IPC_BEGIN_MESSAGE_MAP(PPP_Messaging_Proxy, msg)
84 IPC_MESSAGE_HANDLER(PpapiMsg_PPPMessaging_HandleMessage, 73 IPC_MESSAGE_HANDLER(PpapiMsg_PPPMessaging_HandleMessage,
85 OnMsgHandleMessage) 74 OnMsgHandleMessage)
86 IPC_MESSAGE_UNHANDLED(handled = false) 75 IPC_MESSAGE_UNHANDLED(handled = false)
87 IPC_END_MESSAGE_MAP() 76 IPC_END_MESSAGE_MAP()
88 return handled; 77 return handled;
89 } 78 }
90 79
91 void PPP_Messaging_Proxy::OnMsgHandleMessage( 80 void PPP_Messaging_Proxy::OnMsgHandleMessage(
92 PP_Instance instance, SerializedVarReceiveInput message_data) { 81 PP_Instance instance, SerializedVarReceiveInput message_data) {
93 PP_Var received_var(message_data.GetForInstance(dispatcher(), instance)); 82 PP_Var received_var(message_data.GetForInstance(dispatcher(), instance));
94 // SerializedVarReceiveInput will decrement the reference count, but we want 83 // SerializedVarReceiveInput will decrement the reference count, but we want
95 // to give the recipient a reference. 84 // to give the recipient a reference.
96 PpapiGlobals::Get()->GetVarTracker()->AddRefVar(received_var); 85 PpapiGlobals::Get()->GetVarTracker()->AddRefVar(received_var);
97 CallWhileUnlocked(ppp_messaging_impl_->HandleMessage, 86 CallWhileUnlocked(ppp_messaging_impl_->HandleMessage,
98 instance, 87 instance,
99 received_var); 88 received_var);
100 } 89 }
101 90
102 } // namespace proxy 91 } // namespace proxy
103 } // namespace ppapi 92 } // namespace ppapi
OLDNEW
« no previous file with comments | « ppapi/proxy/ppp_messaging_proxy.h ('k') | ppapi/proxy/ppp_mouse_lock_proxy.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698