diff options
author | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-03-20 20:19:39 +0000 |
---|---|---|
committer | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-03-20 20:19:39 +0000 |
commit | 5b9b80e284fb0b6a4885209ade02093aecc7eb86 (patch) | |
tree | badaaf0bccfb0ea5413c8949250ba50fec420aba /webkit | |
parent | 1769870244a943241f8d34dc01b2d98b4f2b38f4 (diff) | |
download | chromium_src-5b9b80e284fb0b6a4885209ade02093aecc7eb86.zip chromium_src-5b9b80e284fb0b6a4885209ade02093aecc7eb86.tar.gz chromium_src-5b9b80e284fb0b6a4885209ade02093aecc7eb86.tar.bz2 |
Out-of-process implementation of the PPB_NetworkMonitor_Private interface.
BUG=114808
Review URL: http://codereview.chromium.org/9677060
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@127762 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit')
-rw-r--r-- | webkit/plugins/ppapi/ppb_network_monitor_private_impl.cc | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/webkit/plugins/ppapi/ppb_network_monitor_private_impl.cc b/webkit/plugins/ppapi/ppb_network_monitor_private_impl.cc index 1dc2614..813e98f 100644 --- a/webkit/plugins/ppapi/ppb_network_monitor_private_impl.cc +++ b/webkit/plugins/ppapi/ppb_network_monitor_private_impl.cc @@ -6,6 +6,8 @@ #include "base/bind.h" #include "ppapi/shared_impl/ppb_network_list_private_shared.h" +#include "ppapi/shared_impl/private/net_address_private_impl.h" +#include "net/base/ip_endpoint.h" #include "net/base/net_util.h" #include "webkit/plugins/ppapi/resource_helper.h" @@ -56,18 +58,16 @@ bool PPB_NetworkMonitor_Private_Impl::Start() { void PPB_NetworkMonitor_Private_Impl::OnNetworkListChanged( const net::NetworkInterfaceList& list) { - scoped_ptr< ::ppapi::PPB_NetworkList_Private_Shared::NetworkList> list_copy( - new ::ppapi::PPB_NetworkList_Private_Shared::NetworkList(list.size())); + ::ppapi::NetworkList list_copy(list.size()); for (size_t i = 0; i < list.size(); ++i) { - ::ppapi::PPB_NetworkList_Private_Shared::NetworkInfo& network = - list_copy->at(i); + ::ppapi::NetworkInfo& network = list_copy.at(i); network.name = list[i].name; - network.addresses.resize(1); - CHECK_LE(list[i].address.size(), sizeof(network.addresses[0].data)); - network.addresses[0].size = list[i].address.size(); - memcpy(network.addresses[0].data, &(list[i].address.front()), - list[i].address.size()); + network.addresses.resize( + 1, ::ppapi::NetAddressPrivateImpl::kInvalidNetAddress); + bool result = ::ppapi::NetAddressPrivateImpl::IPEndPointToNetAddress( + net::IPEndPoint(list[i].address, 0), &(network.addresses[0])); + DCHECK(result); // TODO(sergeyu): Currently net::NetworkInterfaceList provides // only name and one IP address. Add all other fields and copy @@ -77,9 +77,11 @@ void PPB_NetworkMonitor_Private_Impl::OnNetworkListChanged( network.display_name = list[i].name; network.mtu = 0; } + scoped_refptr< ::ppapi::NetworkListStorage> list_storage( + new ::ppapi::NetworkListStorage(list_copy)); PP_Resource list_resource = ::ppapi::PPB_NetworkList_Private_Shared::Create( - ::ppapi::OBJECT_IS_IMPL, pp_instance(), list_copy.Pass()); + ::ppapi::OBJECT_IS_IMPL, pp_instance(), list_storage); callback_(user_data_, list_resource); } |