Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/ppb_network_monitor_private_proxy.h" | 5 #include "ppapi/proxy/ppb_network_monitor_private_proxy.h" |
| 6 | 6 |
| 7 #include "ppapi/proxy/enter_proxy.h" | 7 #include "ppapi/proxy/enter_proxy.h" |
| 8 #include "ppapi/proxy/ppapi_messages.h" | 8 #include "ppapi/proxy/ppapi_messages.h" |
| 9 #include "ppapi/shared_impl/proxy_lock.h" | 9 #include "ppapi/shared_impl/proxy_lock.h" |
| 10 #include "ppapi/thunk/ppb_network_monitor_private_api.h" | 10 #include "ppapi/thunk/ppb_network_monitor_private_api.h" |
| 11 | 11 |
| 12 namespace ppapi { | 12 namespace ppapi { |
| 13 namespace proxy { | 13 namespace proxy { |
| 14 | 14 |
| 15 class PPB_NetworkMonitor_Private_Proxy::NetworkMonitor | 15 class PPB_NetworkMonitor_Private_Proxy::NetworkMonitor |
| 16 : public Resource, | 16 : public Resource, |
| 17 public thunk::PPB_NetworkMonitor_Private_API, | 17 public thunk::PPB_NetworkMonitor_Private_API, |
| 18 public base::SupportsWeakPtr< | 18 public base::SupportsWeakPtr< |
| 19 PPB_NetworkMonitor_Private_Proxy::NetworkMonitor> { | 19 PPB_NetworkMonitor_Private_Proxy::NetworkMonitor> { |
| 20 public: | 20 public: |
| 21 NetworkMonitor(PP_Instance instance, | 21 NetworkMonitor(PP_Instance instance, |
| 22 PPB_NetworkMonitor_Private_Proxy* proxy, | 22 PPB_NetworkMonitor_Private_Proxy* proxy) |
| 23 PPB_NetworkMonitor_Callback callback, | |
| 24 void* user_data) | |
| 25 : Resource(OBJECT_IS_PROXY, instance), | 23 : Resource(OBJECT_IS_PROXY, instance), |
| 26 proxy_(proxy), | 24 proxy_(proxy), |
| 27 callback_(callback), | 25 initial_list_sent_(false), |
| 28 user_data_(user_data) { | 26 network_list_(NULL) { |
| 29 } | 27 } |
| 30 | 28 |
| 31 virtual ~NetworkMonitor() { | 29 virtual ~NetworkMonitor() { |
| 30 if (TrackedCallback::IsPending(update_callback_)) | |
| 31 update_callback_->PostAbort(); | |
| 32 proxy_->OnNetworkMonitorDeleted(this, pp_instance()); | 32 proxy_->OnNetworkMonitorDeleted(this, pp_instance()); |
| 33 } | 33 } |
| 34 | 34 |
| 35 // thunk::PPB_NetworkMonitor_Private_API interface. | |
| 36 virtual int32_t UpdateNetworkList( | |
| 37 PP_Resource* network_list, | |
| 38 scoped_refptr<TrackedCallback> callback) OVERRIDE { | |
| 39 if (!network_list) | |
| 40 return PP_ERROR_BADARGUMENT; | |
| 41 if (TrackedCallback::IsPending(update_callback_)) | |
| 42 return PP_ERROR_INPROGRESS; | |
| 43 | |
| 44 if (current_list_ && !initial_list_sent_) { | |
| 45 initial_list_sent_ = true; | |
| 46 thunk::EnterResourceCreation enter(pp_instance()); | |
|
yzshen1
2013/09/04 19:52:01
Please use EnterResourceCreationNoLock. At this po
Sergey Ulanov
2013/09/04 22:22:32
Done. Thanks for catching this.
| |
| 47 *network_list = PPB_NetworkList_Private_Shared::Create( | |
| 48 OBJECT_IS_PROXY, pp_instance(), current_list_); | |
| 49 return PP_OK; | |
| 50 } | |
| 51 | |
| 52 network_list_ = network_list; | |
| 53 update_callback_ = callback; | |
| 54 return PP_OK_COMPLETIONPENDING; | |
| 55 } | |
| 35 | 56 |
| 36 // Resource overrides. | 57 // Resource overrides. |
| 37 virtual ppapi::thunk::PPB_NetworkMonitor_Private_API* | 58 virtual ppapi::thunk::PPB_NetworkMonitor_Private_API* |
| 38 AsPPB_NetworkMonitor_Private_API() OVERRIDE { | 59 AsPPB_NetworkMonitor_Private_API() OVERRIDE { |
| 39 return this; | 60 return this; |
| 40 } | 61 } |
| 41 | 62 |
| 42 // This is invoked when a network list is received for this monitor (either | 63 // This is invoked when a network list is received for this monitor (either |
| 43 // initially or on a change). It acquires the ProxyLock inside because | 64 // initially or on a change). It acquires the ProxyLock inside because |
| 44 // ObserverListThreadSafe does not support Bind/Closure, otherwise we would | 65 // ObserverListThreadSafe does not support Bind/Closure, otherwise we would |
| 45 // wrap the call with a lock using RunWhileLocked. | 66 // wrap the call with a lock using RunWhileLocked. |
| 46 void OnNetworkListReceivedLocks( | 67 void OnNetworkListReceivedLocks( |
| 47 const scoped_refptr<NetworkListStorage>& list) { | 68 const scoped_refptr<NetworkListStorage>& list) { |
| 48 ProxyAutoLock lock; | 69 ProxyAutoLock lock; |
| 49 PP_Resource list_resource = | 70 |
| 50 PPB_NetworkList_Private_Shared::Create( | 71 current_list_ = list; |
| 72 | |
| 73 if (TrackedCallback::IsPending(update_callback_)) { | |
| 74 initial_list_sent_ = true; | |
| 75 { | |
| 76 thunk::EnterResourceCreationNoLock enter(pp_instance()); | |
| 77 *network_list_ = PPB_NetworkList_Private_Shared::Create( | |
| 51 OBJECT_IS_PROXY, pp_instance(), list); | 78 OBJECT_IS_PROXY, pp_instance(), list); |
|
yzshen1
2013/09/04 19:52:01
nit: please consider setting network_list_ to NULL
Sergey Ulanov
2013/09/04 22:22:32
Done.
| |
| 52 CallWhileUnlocked(callback_, user_data_, list_resource); | 79 } |
| 80 update_callback_->Run(PP_OK); | |
| 81 } | |
| 53 } | 82 } |
| 54 | 83 |
| 55 private: | 84 private: |
| 56 PPB_NetworkMonitor_Private_Proxy* proxy_; | 85 PPB_NetworkMonitor_Private_Proxy* proxy_; |
| 57 PPB_NetworkMonitor_Callback callback_; | 86 scoped_refptr<NetworkListStorage> current_list_; |
| 58 void* user_data_; | 87 bool initial_list_sent_; |
| 88 | |
| 89 // Parameters passed to UpdateNetworkList(); | |
| 90 PP_Resource* network_list_; | |
| 91 scoped_refptr<TrackedCallback> update_callback_; | |
| 59 | 92 |
| 60 DISALLOW_COPY_AND_ASSIGN(NetworkMonitor); | 93 DISALLOW_COPY_AND_ASSIGN(NetworkMonitor); |
| 61 }; | 94 }; |
| 62 | 95 |
| 63 PPB_NetworkMonitor_Private_Proxy::PPB_NetworkMonitor_Private_Proxy( | 96 PPB_NetworkMonitor_Private_Proxy::PPB_NetworkMonitor_Private_Proxy( |
| 64 Dispatcher* dispatcher) | 97 Dispatcher* dispatcher) |
| 65 : InterfaceProxy(dispatcher), | 98 : InterfaceProxy(dispatcher), |
| 66 monitors_(new ObserverListThreadSafe<NetworkMonitor>()), | 99 monitors_(new ObserverListThreadSafe<NetworkMonitor>()), |
| 67 monitors_count_(0) { | 100 monitors_count_(0) { |
| 68 } | 101 } |
| 69 | 102 |
| 70 PPB_NetworkMonitor_Private_Proxy::~PPB_NetworkMonitor_Private_Proxy() { | 103 PPB_NetworkMonitor_Private_Proxy::~PPB_NetworkMonitor_Private_Proxy() { |
| 71 monitors_->AssertEmpty(); | 104 monitors_->AssertEmpty(); |
| 72 } | 105 } |
| 73 | 106 |
| 74 // static | 107 // static |
| 75 PP_Resource PPB_NetworkMonitor_Private_Proxy::CreateProxyResource( | 108 PP_Resource PPB_NetworkMonitor_Private_Proxy::CreateProxyResource( |
| 76 PP_Instance instance, | 109 PP_Instance instance) { |
| 77 PPB_NetworkMonitor_Callback callback, | |
| 78 void* user_data) { | |
| 79 // TODO(dmichael): Check that this thread has a valid message loop associated | 110 // TODO(dmichael): Check that this thread has a valid message loop associated |
| 80 // with it. | 111 // with it. |
| 81 if (!callback) | |
| 82 return 0; | |
| 83 | |
| 84 PluginDispatcher* dispatcher = PluginDispatcher::GetForInstance(instance); | 112 PluginDispatcher* dispatcher = PluginDispatcher::GetForInstance(instance); |
| 85 if (!dispatcher) | 113 if (!dispatcher) |
| 86 return 0; | 114 return 0; |
| 87 PPB_NetworkMonitor_Private_Proxy* proxy = | 115 PPB_NetworkMonitor_Private_Proxy* proxy = |
| 88 static_cast<PPB_NetworkMonitor_Private_Proxy*>( | 116 static_cast<PPB_NetworkMonitor_Private_Proxy*>( |
| 89 dispatcher->GetInterfaceProxy(kApiID)); | 117 dispatcher->GetInterfaceProxy(kApiID)); |
| 90 if (!proxy) | 118 if (!proxy) |
| 91 return 0; | 119 return 0; |
| 92 | 120 |
| 93 scoped_refptr<NetworkMonitor> result( | 121 scoped_refptr<NetworkMonitor> result(new NetworkMonitor(instance, proxy)); |
| 94 new NetworkMonitor(instance, proxy, callback, user_data)); | |
| 95 proxy->monitors_->AddObserver(result.get()); | 122 proxy->monitors_->AddObserver(result.get()); |
| 96 | 123 |
| 97 proxy->monitors_count_++; | 124 proxy->monitors_count_++; |
| 98 if (proxy->monitors_count_ == 1) { | 125 if (proxy->monitors_count_ == 1) { |
| 99 // If that is the first network monitor then send Start message. | 126 // If that is the first network monitor then send Start message. |
| 100 PluginGlobals::Get()->GetBrowserSender()->Send( | 127 PluginGlobals::Get()->GetBrowserSender()->Send( |
| 101 new PpapiHostMsg_PPBNetworkMonitor_Start( | 128 new PpapiHostMsg_PPBNetworkMonitor_Start( |
| 102 dispatcher->plugin_dispatcher_id())); | 129 dispatcher->plugin_dispatcher_id())); |
| 103 | 130 |
| 104 // We could have received network list message after sending the | 131 // We could have received network list message after sending the |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 147 PluginGlobals::Get()->GetBrowserSender()->Send( | 174 PluginGlobals::Get()->GetBrowserSender()->Send( |
| 148 new PpapiHostMsg_PPBNetworkMonitor_Stop( | 175 new PpapiHostMsg_PPBNetworkMonitor_Stop( |
| 149 dispatcher->plugin_dispatcher_id())); | 176 dispatcher->plugin_dispatcher_id())); |
| 150 } | 177 } |
| 151 current_list_ = NULL; | 178 current_list_ = NULL; |
| 152 } | 179 } |
| 153 } | 180 } |
| 154 | 181 |
| 155 } // namespace proxy | 182 } // namespace proxy |
| 156 } // namespace ppapi | 183 } // namespace ppapi |
| OLD | NEW |