diff --git a/src/libstd/net/addr.rs b/src/libstd/net/addr.rs index 1ce37f6cc0a16..f5348934310e8 100644 --- a/src/libstd/net/addr.rs +++ b/src/libstd/net/addr.rs @@ -446,6 +446,20 @@ impl FromInner for SocketAddrV6 { } } +#[stable(feature = "ip_from_ip", since = "1.16.0")] +impl From for SocketAddr { + fn from(sock4: SocketAddrV4) -> SocketAddr { + SocketAddr::V4(sock4) + } +} + +#[stable(feature = "ip_from_ip", since = "1.16.0")] +impl From 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 6aab7486004f8..249f1c76680c1 100644 --- a/src/libstd/net/ip.rs +++ b/src/libstd/net/ip.rs @@ -524,6 +524,20 @@ impl fmt::Display for IpAddr { } } +#[stable(feature = "ip_from_ip", since = "1.16.0")] +impl From for IpAddr { + fn from(ipv4: Ipv4Addr) -> IpAddr { + IpAddr::V4(ipv4) + } +} + +#[stable(feature = "ip_from_ip", since = "1.16.0")] +impl From for IpAddr { + fn from(ipv6: Ipv6Addr) -> IpAddr { + IpAddr::V6(ipv6) + } +} + #[stable(feature = "rust1", since = "1.0.0")] impl fmt::Display for Ipv4Addr { fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {