Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "chrome/browser/local_discovery/service_discovery_client_mdns.h" | 5 #include "chrome/browser/local_discovery/service_discovery_client_mdns.h" |
| 6 | 6 |
| 7 #include "base/location.h" | 7 #include "base/location.h" |
| 8 #include "base/memory/scoped_vector.h" | 8 #include "base/memory/scoped_vector.h" |
|
mmenke
2015/11/24 17:39:33
Remove, include scoped_ptr, vector instead.
| |
| 9 #include "base/metrics/histogram.h" | 9 #include "base/metrics/histogram.h" |
| 10 #include "base/single_thread_task_runner.h" | 10 #include "base/single_thread_task_runner.h" |
| 11 #include "base/thread_task_runner_handle.h" | 11 #include "base/thread_task_runner_handle.h" |
| 12 #include "chrome/common/local_discovery/service_discovery_client_impl.h" | 12 #include "chrome/common/local_discovery/service_discovery_client_impl.h" |
| 13 #include "content/public/browser/browser_thread.h" | 13 #include "content/public/browser/browser_thread.h" |
| 14 #include "net/dns/mdns_client.h" | 14 #include "net/dns/mdns_client.h" |
| 15 #include "net/udp/datagram_server_socket.h" | 15 #include "net/udp/datagram_server_socket.h" |
| 16 | 16 |
| 17 namespace local_discovery { | 17 namespace local_discovery { |
| 18 | 18 |
| (...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 108 | 108 |
| 109 typedef base::Callback<void(bool)> MdnsInitCallback; | 109 typedef base::Callback<void(bool)> MdnsInitCallback; |
| 110 | 110 |
| 111 class SocketFactory : public net::MDnsSocketFactory { | 111 class SocketFactory : public net::MDnsSocketFactory { |
| 112 public: | 112 public: |
| 113 explicit SocketFactory(const net::InterfaceIndexFamilyList& interfaces) | 113 explicit SocketFactory(const net::InterfaceIndexFamilyList& interfaces) |
| 114 : interfaces_(interfaces) {} | 114 : interfaces_(interfaces) {} |
| 115 | 115 |
| 116 // net::MDnsSocketFactory implementation: | 116 // net::MDnsSocketFactory implementation: |
| 117 void CreateSockets( | 117 void CreateSockets( |
| 118 ScopedVector<net::DatagramServerSocket>* sockets) override { | 118 std::vector<scoped_ptr<net::DatagramServerSocket>>* sockets) override { |
| 119 for (size_t i = 0; i < interfaces_.size(); ++i) { | 119 for (size_t i = 0; i < interfaces_.size(); ++i) { |
| 120 DCHECK(interfaces_[i].second == net::ADDRESS_FAMILY_IPV4 || | 120 DCHECK(interfaces_[i].second == net::ADDRESS_FAMILY_IPV4 || |
| 121 interfaces_[i].second == net::ADDRESS_FAMILY_IPV6); | 121 interfaces_[i].second == net::ADDRESS_FAMILY_IPV6); |
| 122 scoped_ptr<net::DatagramServerSocket> socket( | 122 scoped_ptr<net::DatagramServerSocket> socket( |
| 123 CreateAndBindMDnsSocket(interfaces_[i].second, interfaces_[i].first)); | 123 CreateAndBindMDnsSocket(interfaces_[i].second, interfaces_[i].first)); |
| 124 if (socket) | 124 if (socket) |
| 125 sockets->push_back(socket.release()); | 125 sockets->push_back(std::move(socket)); |
| 126 } | 126 } |
| 127 } | 127 } |
| 128 | 128 |
| 129 private: | 129 private: |
| 130 net::InterfaceIndexFamilyList interfaces_; | 130 net::InterfaceIndexFamilyList interfaces_; |
| 131 }; | 131 }; |
| 132 | 132 |
| 133 void InitMdns(const MdnsInitCallback& on_initialized, | 133 void InitMdns(const MdnsInitCallback& on_initialized, |
| 134 const net::InterfaceIndexFamilyList& interfaces, | 134 const net::InterfaceIndexFamilyList& interfaces, |
| 135 net::MDnsClient* mdns) { | 135 net::MDnsClient* mdns) { |
| (...skipping 298 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 434 OnBeforeMdnsDestroy(); | 434 OnBeforeMdnsDestroy(); |
| 435 // After calling |Proxy::OnMdnsDestroy| all references to client_ and mdns_ | 435 // After calling |Proxy::OnMdnsDestroy| all references to client_ and mdns_ |
| 436 // should be destroyed. | 436 // should be destroyed. |
| 437 if (client_) | 437 if (client_) |
| 438 mdns_runner_->DeleteSoon(FROM_HERE, client_.release()); | 438 mdns_runner_->DeleteSoon(FROM_HERE, client_.release()); |
| 439 if (mdns_) | 439 if (mdns_) |
| 440 mdns_runner_->DeleteSoon(FROM_HERE, mdns_.release()); | 440 mdns_runner_->DeleteSoon(FROM_HERE, mdns_.release()); |
| 441 } | 441 } |
| 442 | 442 |
| 443 } // namespace local_discovery | 443 } // namespace local_discovery |
| OLD | NEW |