Creates an async-io-state where object is an unconnected UDP socket.
comm
create-async-io-state-and-udp-socket collection &key name errorp ipv6 queue-output read-timeout write-timeout user-info local-address local-port => async-io-state
| collection⇩ |
A wait-state-collection to associate with the returned async-io-state. |
| name⇩ |
A Lisp object. |
| errorp⇩ |
A boolean. |
| ipv6⇩ |
One of nil, t, the keyword :any or the keyword :both. |
| queue-output⇩ |
A boolean. |
| read-timeout⇩ | nil or a positive real. |
| write-timeout⇩ | nil or a positive real. |
| user-info⇩ |
A Lisp object. |
|
Specify the local socket address in the standard way. | |
| async-io-state⇩ |
An async-io-state or nil. |
The function create-async-io-state-and-udp-socket creates an async-io-state where object is an unconnected UDP socket.
async-io-state is associated with collection.
create-async-io-state-and-udp-socket creates a new UDP socket, optionally binds it if local-port or local-address is non-nil, and then creates and returns an async-io-state object that can be used to perform I/O operations on the socket. The I/O operations are performed using async-io-state-receive-message and async-io-state-send-message-to-address. local-address and local-port specify the local socket address as described in 25.4 Specifying the target for connecting and binding a socket. Both values can be nil.
queue-output controls what happens if you try to perform a write operation on the state while another write operation is ongoing. When nil, this will cause an error. When non-nil, the second write operation is queued and actually executed later. The default value of queue-output is t.
When ipv6 is :any, the system selects whether to use an IPv4 or IPv6 socket (normally it will be IPv4). When ipv6 is t it forces using IPv6, and nil forces IPv4. The value :both means using IPv6, but also allow receiving messages in IPv4. The default value of ipv6 is :any.
When errorp is nil, create-async-io-state-and-udp-socket returns nil for run time errors rather than signaling an error. The default value of errorp is t.
read-timeout, write-timeout, user-info and name are set the new async-io-state using the corresponding accessors async-io-state-read-timeout, async-io-state-write-timeout, async-io-state-user-info and async-io-state-name.
The default value of name is a string "UDP".
create-async-io-state-and-udp-socket by supplying needs-address t to async-io-state-receive-message.create-async-io-state-and-udp-socket itself is synchronous.create-async-io-state-and-udp-socket (because the socket address to send to must be specified).
(example-edit-file "async-io/udp")
async-io-state-receive-message
async-io-state-send-message-to-address
create-async-io-state-and-connected-udp-socket
25.8.2 The Async-I/O-State API
25 TCP and UDP socket communication and SSL
LispWorks® User Guide and Reference Manual - 18 Feb 2025 15:32:11