]> git.lizzy.rs Git - rust.git/blob - library/std/src/net/mod.rs
Rollup merge of #107074 - lcnr:validate-dont-skip-opaque, r=compiler-errors
[rust.git] / library / std / src / net / mod.rs
1 //! Networking primitives for TCP/UDP communication.
2 //!
3 //! This module provides networking functionality for the Transmission Control and User
4 //! Datagram Protocols, as well as types for IP and socket addresses.
5 //!
6 //! # Organization
7 //!
8 //! * [`TcpListener`] and [`TcpStream`] provide functionality for communication over TCP
9 //! * [`UdpSocket`] provides functionality for communication over UDP
10 //! * [`IpAddr`] represents IP addresses of either IPv4 or IPv6; [`Ipv4Addr`] and
11 //!   [`Ipv6Addr`] are respectively IPv4 and IPv6 addresses
12 //! * [`SocketAddr`] represents socket addresses of either IPv4 or IPv6; [`SocketAddrV4`]
13 //!   and [`SocketAddrV6`] are respectively IPv4 and IPv6 socket addresses
14 //! * [`ToSocketAddrs`] is a trait that is used for generic address resolution when interacting
15 //!   with networking objects like [`TcpListener`], [`TcpStream`] or [`UdpSocket`]
16 //! * Other types are return or parameter types for various methods in this module
17 //!
18 //! Rust disables inheritance of socket objects to child processes by default when possible.  For
19 //! example, through the use of the `CLOEXEC` flag in UNIX systems or the `HANDLE_FLAG_INHERIT`
20 //! flag on Windows.
21
22 #![stable(feature = "rust1", since = "1.0.0")]
23
24 use crate::io::{self, ErrorKind};
25
26 #[stable(feature = "rust1", since = "1.0.0")]
27 pub use self::ip_addr::{IpAddr, Ipv4Addr, Ipv6Addr, Ipv6MulticastScope};
28 #[stable(feature = "rust1", since = "1.0.0")]
29 pub use self::parser::AddrParseError;
30 #[stable(feature = "rust1", since = "1.0.0")]
31 pub use self::socket_addr::{SocketAddr, SocketAddrV4, SocketAddrV6, ToSocketAddrs};
32 #[unstable(feature = "tcplistener_into_incoming", issue = "88339")]
33 pub use self::tcp::IntoIncoming;
34 #[stable(feature = "rust1", since = "1.0.0")]
35 pub use self::tcp::{Incoming, TcpListener, TcpStream};
36 #[stable(feature = "rust1", since = "1.0.0")]
37 pub use self::udp::UdpSocket;
38
39 mod display_buffer;
40 mod ip_addr;
41 mod parser;
42 mod socket_addr;
43 mod tcp;
44 #[cfg(test)]
45 pub(crate) mod test;
46 mod udp;
47
48 /// Possible values which can be passed to the [`TcpStream::shutdown`] method.
49 #[derive(Copy, Clone, PartialEq, Eq, Debug)]
50 #[stable(feature = "rust1", since = "1.0.0")]
51 pub enum Shutdown {
52     /// The reading portion of the [`TcpStream`] should be shut down.
53     ///
54     /// All currently blocked and future [reads] will return <code>[Ok]\(0)</code>.
55     ///
56     /// [reads]: crate::io::Read "io::Read"
57     #[stable(feature = "rust1", since = "1.0.0")]
58     Read,
59     /// The writing portion of the [`TcpStream`] should be shut down.
60     ///
61     /// All currently blocked and future [writes] will return an error.
62     ///
63     /// [writes]: crate::io::Write "io::Write"
64     #[stable(feature = "rust1", since = "1.0.0")]
65     Write,
66     /// Both the reading and the writing portions of the [`TcpStream`] should be shut down.
67     ///
68     /// See [`Shutdown::Read`] and [`Shutdown::Write`] for more information.
69     #[stable(feature = "rust1", since = "1.0.0")]
70     Both,
71 }
72
73 fn each_addr<A: ToSocketAddrs, F, T>(addr: A, mut f: F) -> io::Result<T>
74 where
75     F: FnMut(io::Result<&SocketAddr>) -> io::Result<T>,
76 {
77     let addrs = match addr.to_socket_addrs() {
78         Ok(addrs) => addrs,
79         Err(e) => return f(Err(e)),
80     };
81     let mut last_err = None;
82     for addr in addrs {
83         match f(Ok(&addr)) {
84             Ok(l) => return Ok(l),
85             Err(e) => last_err = Some(e),
86         }
87     }
88     Err(last_err.unwrap_or_else(|| {
89         io::const_io_error!(ErrorKind::InvalidInput, "could not resolve to any addresses")
90     }))
91 }