diff options
| author | Yamakaky <yamakaky@yamaworld.fr> | 2016-12-12 15:34:09 -0500 |
|---|---|---|
| committer | Yamakaky <yamakaky@yamaworld.fr> | 2016-12-25 18:10:03 -0500 |
| commit | 2d365c6b7ae0ed76d85e6dccaccc5782728e5d0b (patch) | |
| tree | 62ddd5cfd8c3054e8ef875a076a3d113322a8438 /src/libstd/net | |
| parent | 40053a46ff3b5d7a516d1f91e89cd928cf253347 (diff) | |
| download | rust-2d365c6b7ae0ed76d85e6dccaccc5782728e5d0b.tar.gz rust-2d365c6b7ae0ed76d85e6dccaccc5782728e5d0b.zip | |
Impl From<inner> for IpAddr and SocketAddr.
Fixes https://github.com/rust-lang/rfcs/issues/1816.
Diffstat (limited to 'src/libstd/net')
| -rw-r--r-- | src/libstd/net/addr.rs | 14 | ||||
| -rw-r--r-- | src/libstd/net/ip.rs | 2 |
2 files changed, 16 insertions, 0 deletions
diff --git a/src/libstd/net/addr.rs b/src/libstd/net/addr.rs index 1ce37f6cc0a..f5348934310 100644 --- a/src/libstd/net/addr.rs +++ b/src/libstd/net/addr.rs @@ -446,6 +446,20 @@ impl FromInner<c::sockaddr_in6> for SocketAddrV6 { } } +#[stable(feature = "ip_from_ip", since = "1.16.0")] +impl From<SocketAddrV4> for SocketAddr { + fn from(sock4: SocketAddrV4) -> SocketAddr { + SocketAddr::V4(sock4) + } +} + +#[stable(feature = "ip_from_ip", since = "1.16.0")] +impl From<SocketAddrV6> for SocketAddr { + fn from(sock6: SocketAddrV6) -> SocketAddr { + SocketAddr::V6(sock6) + } +} + impl<'a> IntoInner<(*const c::sockaddr, c::socklen_t)> for &'a SocketAddr { fn into_inner(self) -> (*const c::sockaddr, c::socklen_t) { match *self { diff --git a/src/libstd/net/ip.rs b/src/libstd/net/ip.rs index 36a1aed8400..249f1c76680 100644 --- a/src/libstd/net/ip.rs +++ b/src/libstd/net/ip.rs @@ -524,12 +524,14 @@ impl fmt::Display for IpAddr { } } +#[stable(feature = "ip_from_ip", since = "1.16.0")] impl From<Ipv4Addr> for IpAddr { fn from(ipv4: Ipv4Addr) -> IpAddr { IpAddr::V4(ipv4) } } +#[stable(feature = "ip_from_ip", since = "1.16.0")] impl From<Ipv6Addr> for IpAddr { fn from(ipv6: Ipv6Addr) -> IpAddr { IpAddr::V6(ipv6) |
