summaryrefslogtreecommitdiffstats
path: root/txr.1
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2016-03-19 06:54:14 -0700
committerKaz Kylheku <kaz@kylheku.com>2016-03-19 06:54:14 -0700
commitea9ba58da58fc03e4b1ae1d6e277dad8189fa920 (patch)
treedca22ce43dcfaf3489ddf33513b94ab41b786655 /txr.1
parent5e3c8d5663f7c7f001669bb9d91485244f8ce799 (diff)
downloadtxr-ea9ba58da58fc03e4b1ae1d6e277dad8189fa920.tar.gz
txr-ea9ba58da58fc03e4b1ae1d6e277dad8189fa920.tar.bz2
txr-ea9ba58da58fc03e4b1ae1d6e277dad8189fa920.zip
Size mode meaningful in datagram sockets.
* socket.c (struct dgram_stream): new rx_max member. (make_dgram_sock_stream): New arguments: a struct stdio_mode, and pointer to prototype dgram socket. If a size is specified in the mode, then use that as rx_max. Otherwise if a prototype socket is specified, use its rx_max as the new socket's rx_max. Otherwise default on 65536. (dgram_get_byte_callback): Use d->rx_max as the capture size, rather than a hard-coded 65536. (sock_accept): Use d->rx_max as capture size for datagram. Parse the mode. Pass the parsed mode to make_dgram_sock_stream, as well as the accepting socket, so it can set up the rx_max for the new socket. (open_sockfd): Parse the mode and pass to make_dgram_sock_stream. * stream.c (parse_mode): Static function becomes extern. * stream.h (parse_mode): Declared. * txr.1: Documented.
Diffstat (limited to 'txr.1')
-rw-r--r--txr.126
1 files changed, 26 insertions, 0 deletions
diff --git a/txr.1 b/txr.1
index 6adb7dfa..ff3d6481 100644
--- a/txr.1
+++ b/txr.1
@@ -37527,6 +37527,32 @@ Datagram servers should issue a new
call should be issued for each client datagram, treating it as a new
stream.
+Datagram sockets ignore almost all aspects of the
+.meta mode-string
+passed in
+.code open-socket
+and
+.codn sock-accept .
+The only attribute not ignored is the buffer size specified
+with a decimal digit character; however, it cannot be the
+only item in the mode string. The string must be syntactically
+valid, as described under the
+.code open-file
+function. The buffer size attribute controls the size used by
+the datagram socket for receiving a datagram: the capture size.
+A datagram socket has obtains a default capture size if one isn't
+specified by the
+.metn mode-string .
+The default capture size is 65536 bytes for a datagram socket created by
+.codn open-socket .
+If a size is not passed to
+.code sock-accept
+via its
+.meta mode-string
+argument when it is invoked on a datagram socket,
+that socket's size is used as the capture size of the
+newly created datagram socket which is returned.
+
.coNP Structure @ sockaddr
.synb
.mets (defstruct sockaddr nil)