net
The net module provides some general-purpose interfaces and support code, but generally users are directed to the submodules, where implementations of various network protocols are provided, such as net::tcp:: or net::dns::.
A porcelain API for establishing an outgoing connection, able to automatically handle matters such as DNS resolution, is available at net::dial::.
Submodules
Index
Types
type shut = enum {
RD, WR, RDWR, };
type socket = io::file;
type sockflag = enum {
NOCLOEXEC = rt::SOCK_CLOEXEC,
NONBLOCK = rt::SOCK_NONBLOCK,
DGRAM = rt::SOCK_DGRAM,
};
type msghdr = struct {
native: rt::msghdr,
vectors: []rt::iovec,
control: []u8,
};
Errors
type error = !(unknownproto | ...errors::error);
type unknownproto = !void;
Functions
fn accept(sock: socket, flags: sockflag = 0) (socket | error);
fn addcontrol(msg: *msghdr, length: size, level: int, ctype: int) []u8;
fn addvector(msg: *msghdr, vec: []u8) void;
fn close(sock: socket) (void | error);
fn finish(msg: *msghdr) void;
fn getcontrol(msg: *msghdr, length: size, level: int, ctype: int) ([]u8 | void);
fn getflags(msg: *msghdr) int;
fn newmsg() msghdr;
fn recvmsg(sock: socket, msg: *msghdr) (size | error);
fn reset(msg: *msghdr) void;
fn sendmsg(sock: socket, msg: *msghdr) (size | error);
fn setflags(msg: *msghdr, flags: int) void;
fn setname(msg: *msghdr, name: *opaque, length: size) void;
fn shutdown(sock: socket, how: shut) (void | error);
fn strerror(err: error) const str;
Types
type shut
type shut = enum {
RD, WR, RDWR, };
The end of the full-duplex connection that should be shutdown.
type socket
type socket = io::file;
A network socket.
type sockflag
type sockflag = enum {
NOCLOEXEC = rt::SOCK_CLOEXEC,
NONBLOCK = rt::SOCK_NONBLOCK,
DGRAM = rt::SOCK_DGRAM,
};
Optional flags to accept to be set on the returned socket. See the O_CLOEXEC and O_NONBLOCK sections of open(2) for details. Note that CLOEXEC is on by default, and NOCLOEXEC flag disables it.
type msghdr
Show undocumented member
type msghdr = struct {
native: rt::msghdr,
vectors: []rt::iovec,
control: []u8,
};
Errors
type error
type error = !(unknownproto | ...errors::error);
All error types which can be returned from networking functions.
type unknownproto
type unknownproto = !void;
An attempt was made to use an unsupported protocol.
Functions
fn accept
fn accept(sock: socket, flags: sockflag = 0) (socket | error);
Accepts the next connection from a socket. Blocks until a new connection is available. Optionally accepts NOCLOEXEC and NONBLOCK flags. If flags are supplied, the io::file returned will have the supplied flags set.
fn addcontrol
fn addcontrol(msg: *msghdr, length: size, level: int, ctype: int) []u8;
Adds a control message of the desired length to a msghdr, returning a buffer in which the ancillary data may be written in a domain-specific format.
This is a low-level interface, and is not generally used by users. More often, users will call functions like net::unix::addfiles or net::unix::allocfiles, which provide a high-level interface to this function for domain-specific use-cases.
fn addvector
fn addvector(msg: *msghdr, vec: []u8) void;
Adds an I/O vector to the message.
fn close
fn close(sock: socket) (void | error);
Closes a socket. No further operations against this socket are permitted after calling this function. Closing a socket can fail only under certain conditions (for example, closing a socket twice, or an interrupted syscall). However, the user should not attempt to close the file again on failure - at best the user should print a diagnostic message and move on. See close(2) for details.
On Linux, this function is an alias for io::close.
fn finish
fn finish(msg: *msghdr) void;
Frees resources associated with a msghdr.
fn getcontrol
fn getcontrol(msg: *msghdr, length: size, level: int, ctype: int) ([]u8 | void);
Retrieves a control header from a message, returning a slice of domain-specific data.
This is a low-level interface, and is not generally used by users. More often, users will call functions like net::unix::addfiles or net::unix::allocfiles, which provide a high-level interface to this function for domain-specific use-cases.
fn getflags
fn getflags(msg: *msghdr) int;
Get flags for this message.
fn newmsg
fn newmsg() msghdr;
Creates a new message header for advanced socket usage, with configurable I/O vectors, control messages, and other details, for use with sendmsg and recvmsg.
The user must call finish when they are done using this message for sending or receiving. The same message may be used for multiple operations before calling finish. reset may be used to "reset" a msghdr to an empty list of I/O vectors and control messages without freeing the underlying memory, which may be useful if future messages are expected to have similar characteristics.
fn recvmsg
fn recvmsg(sock: socket, msg: *msghdr) (size | error);
Receives a message from a socket. See newmsg for details.
fn reset
fn reset(msg: *msghdr) void;
Resets a message header, clearing out any I/O vectors or control messages, without freeing the underlying memory. This allows the user to configure new vectors or control messages without a re-allocation, which improves performance if the new configuration fits into the same amount of memory.
fn sendmsg
fn sendmsg(sock: socket, msg: *msghdr) (size | error);
Sends a message to a socket. See newmsg for details.
fn setflags
fn setflags(msg: *msghdr, flags: int) void;
Sets flags for this message.
fn setname
fn setname(msg: *msghdr, name: *opaque, length: size) void;
Sets name for this message.
fn shutdown
fn shutdown(sock: socket, how: shut) (void | error);
Shuts down part of a full-duplex connection.
fn strerror
fn strerror(err: error) const str;
Converts an error into a human-readable string.