Sha256: c52b9bf91ef4e30e7ec08ad1fc9e77ef005a0a87648c5d2e416dd6e35369f08c
Contents?: true
Size: 1.55 KB
Versions: 8
Compression:
Stored size: 1.55 KB
Contents
@since(version = 0.2.0) interface udp-create-socket { @since(version = 0.2.0) use network.{network, error-code, ip-address-family}; @since(version = 0.2.0) use udp.{udp-socket}; /// Create a new UDP socket. /// /// Similar to `socket(AF_INET or AF_INET6, SOCK_DGRAM, IPPROTO_UDP)` in POSIX. /// On IPv6 sockets, IPV6_V6ONLY is enabled by default and can't be configured otherwise. /// /// This function does not require a network capability handle. This is considered to be safe because /// at time of creation, the socket is not bound to any `network` yet. Up to the moment `bind` is called, /// the socket is effectively an in-memory configuration object, unable to communicate with the outside world. /// /// All sockets are non-blocking. Use the wasi-poll interface to block on asynchronous operations. /// /// # Typical errors /// - `not-supported`: The specified `address-family` is not supported. (EAFNOSUPPORT) /// - `new-socket-limit`: The new socket resource could not be created because of a system limit. (EMFILE, ENFILE) /// /// # References: /// - <https://pubs.opengroup.org/onlinepubs/9699919799/functions/socket.html> /// - <https://man7.org/linux/man-pages/man2/socket.2.html> /// - <https://learn.microsoft.com/en-us/windows/win32/api/winsock2/nf-winsock2-wsasocketw> /// - <https://man.freebsd.org/cgi/man.cgi?query=socket&sektion=2> @since(version = 0.2.0) create-udp-socket: func(address-family: ip-address-family) -> result<udp-socket, error-code>; }
Version data entries
8 entries across 8 versions & 1 rubygems