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 #ifndef NET_BASE_IP_ENDPOINT_H_ | 5 #ifndef NET_BASE_IP_ENDPOINT_H_ |
6 #define NET_BASE_IP_ENDPOINT_H_ | 6 #define NET_BASE_IP_ENDPOINT_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
11 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
12 #include "net/base/address_family.h" | 12 #include "net/base/address_family.h" |
| 13 #include "net/base/ip_address.h" |
13 #include "net/base/ip_address_number.h" | 14 #include "net/base/ip_address_number.h" |
14 #include "net/base/net_export.h" | 15 #include "net/base/net_export.h" |
15 #include "net/base/sys_addrinfo.h" | 16 #include "net/base/sys_addrinfo.h" |
16 | 17 |
17 struct sockaddr; | 18 struct sockaddr; |
18 | 19 |
19 namespace net { | 20 namespace net { |
20 | 21 |
21 // An IPEndPoint represents the address of a transport endpoint: | 22 // An IPEndPoint represents the address of a transport endpoint: |
22 // * IP address (either v4 or v6) | 23 // * IP address (either v4 or v6) |
23 // * Port | 24 // * Port |
24 class NET_EXPORT IPEndPoint { | 25 class NET_EXPORT IPEndPoint { |
25 public: | 26 public: |
26 IPEndPoint(); | 27 IPEndPoint(); |
27 ~IPEndPoint(); | 28 ~IPEndPoint(); |
28 IPEndPoint(const IPAddressNumber& address, uint16_t port); | 29 IPEndPoint(const IPAddressNumber& address, uint16_t port); |
| 30 IPEndPoint(const IPAddress& address, uint16_t port); |
29 IPEndPoint(const IPEndPoint& endpoint); | 31 IPEndPoint(const IPEndPoint& endpoint); |
30 | 32 |
31 const IPAddressNumber& address() const { return address_; } | 33 // TODO(Martijnc): Remove the old version when all consumers are moved to |
| 34 // IPAddress. https://crbug.com/496258 |
| 35 const IPAddressNumber& address() const { return address_.ip_address_; } |
| 36 const IPAddress& addressNew() const { return address_; } |
32 uint16_t port() const { return port_; } | 37 uint16_t port() const { return port_; } |
33 | 38 |
34 // Returns AddressFamily of the address. | 39 // Returns AddressFamily of the address. |
35 AddressFamily GetFamily() const; | 40 AddressFamily GetFamily() const; |
36 | 41 |
37 // Returns the sockaddr family of the address, AF_INET or AF_INET6. | 42 // Returns the sockaddr family of the address, AF_INET or AF_INET6. |
38 int GetSockAddrFamily() const; | 43 int GetSockAddrFamily() const; |
39 | 44 |
40 // Convert to a provided sockaddr struct. | 45 // Convert to a provided sockaddr struct. |
41 // |address| is the sockaddr to copy into. Should be at least | 46 // |address| is the sockaddr to copy into. Should be at least |
(...skipping 16 matching lines...) Expand all Loading... |
58 // valid. | 63 // valid. |
59 std::string ToString() const; | 64 std::string ToString() const; |
60 | 65 |
61 // As above, but without port. | 66 // As above, but without port. |
62 std::string ToStringWithoutPort() const; | 67 std::string ToStringWithoutPort() const; |
63 | 68 |
64 bool operator<(const IPEndPoint& that) const; | 69 bool operator<(const IPEndPoint& that) const; |
65 bool operator==(const IPEndPoint& that) const; | 70 bool operator==(const IPEndPoint& that) const; |
66 | 71 |
67 private: | 72 private: |
68 IPAddressNumber address_; | 73 IPAddress address_; |
69 uint16_t port_; | 74 uint16_t port_; |
70 }; | 75 }; |
71 | 76 |
72 } // namespace net | 77 } // namespace net |
73 | 78 |
74 #endif // NET_BASE_IP_ENDPOINT_H_ | 79 #endif // NET_BASE_IP_ENDPOINT_H_ |
OLD | NEW |