A tap for listening TCP sockets
IO::Socket::Async::ListenSocket is returned by the
tap|/type/Supply#method_tap method when called on the Supply returned by calling the listen method of IO::Socket::Async, which represents a listening TCP socket:
my IO::Socket::Async::ListenSocket =IO::Socket::Async.listen('127.0.0.1', 0).tap(->);my (Str , Int ) = await .socket-host, .socket-port;say "The rude service is listening on $host:$port for the next 10 seconds...";await Promise.in(10).then();say "I'm done now.";
Alternatively, by using the
do prefix with
whenever, you can also use it from within a
method socket-host(--> Promise)
Returns a Promise that will be kept with a
Str|/type/Str containing the address of the listening socket.
method socket-port(--> Promise)
Returns a Promise that will be kept with an
Int|/type/Int containing the port of the listening socket.
method native-descriptor(--> Int)
Returns the corresponding file descriptor (
SOCKET on Windows) for the listening socket.
IO::Socket::Async::ListenSocket inherits from class Tap, which provides the following routines:
Closes the tap.