Blame examples/nonblocking_libasyncns.pl

Packit Service 64bc36
#!/usr/bin/perl
Packit Service 64bc36
Packit Service 64bc36
use strict;
Packit Service 64bc36
use warnings;
Packit Service 64bc36
Packit Service 64bc36
use Errno qw( EINPROGRESS );
Packit Service 64bc36
use IO::Poll;
Packit Service 64bc36
use IO::Socket::IP;
Packit Service 64bc36
use Net::LibAsyncNS;
Packit Service 64bc36
use Socket qw( SOCK_STREAM );
Packit Service 64bc36
Packit Service 64bc36
my $host    = shift @ARGV or die "Need HOST\n";
Packit Service 64bc36
my $service = shift @ARGV or die "Need SERVICE\n";
Packit Service 64bc36
Packit Service 64bc36
my $poll = IO::Poll->new;
Packit Service 64bc36
Packit Service 64bc36
my $asyncns = Net::LibAsyncNS->new( 1 );
Packit Service 64bc36
my $asyncns_fh = $asyncns->new_handle_for_fd;
Packit Service 64bc36
Packit Service 64bc36
my $q = $asyncns->getaddrinfo( $host, $service, { socktype => SOCK_STREAM } );
Packit Service 64bc36
Packit Service 64bc36
$poll->mask( $asyncns_fh => POLLIN );
Packit Service 64bc36
Packit Service 64bc36
while( !$q->isdone ) {
Packit Service 64bc36
   $poll->poll( undef );
Packit Service 64bc36
Packit Service 64bc36
   if( $poll->events( $asyncns_fh ) ) {
Packit Service 64bc36
      $asyncns->wait( 0 );
Packit Service 64bc36
   }
Packit Service 64bc36
}
Packit Service 64bc36
Packit Service 64bc36
$poll->mask( $asyncns_fh => 0 );
Packit Service 64bc36
Packit Service 64bc36
my ( $err, @peeraddrinfo ) = $asyncns->getaddrinfo_done( $q );
Packit Service 64bc36
$err and die "getaddrinfo() - $!";
Packit Service 64bc36
Packit Service 64bc36
my $socket = IO::Socket::IP->new(
Packit Service 64bc36
   PeerAddrInfo => \@peeraddrinfo,
Packit Service 64bc36
   Blocking     => 0,
Packit Service 64bc36
) or die "Cannot construct socket - $@";
Packit Service 64bc36
Packit Service 64bc36
$poll->mask( $socket => POLLOUT );
Packit Service 64bc36
Packit Service 64bc36
while(1) {
Packit Service 64bc36
   $poll->poll( undef );
Packit Service 64bc36
Packit Service 64bc36
   if( $poll->events( $socket ) & POLLOUT ) {
Packit Service 64bc36
      last if $socket->connect;
Packit Service 64bc36
      die "Cannot connect - $!" unless $! == EINPROGRESS;
Packit Service 64bc36
   }
Packit Service 64bc36
}
Packit Service 64bc36
Packit Service 64bc36
printf STDERR "Connected to %s:%s\n", $socket->peerhost_service;
Packit Service 64bc36
Packit Service 64bc36
$poll->mask( \*STDIN => POLLIN );
Packit Service 64bc36
$poll->mask( $socket => POLLIN );
Packit Service 64bc36
Packit Service 64bc36
while(1) {
Packit Service 64bc36
   $poll->poll( undef );
Packit Service 64bc36
Packit Service 64bc36
   if( $poll->events( \*STDIN ) ) {
Packit Service 64bc36
      my $ret = STDIN->sysread( my $buffer, 8192 );
Packit Service 64bc36
      defined $ret or die "Cannot read STDIN - $!\n";
Packit Service 64bc36
      $ret or last;
Packit Service 64bc36
      $socket->syswrite( $buffer );
Packit Service 64bc36
   }
Packit Service 64bc36
   if( $poll->events( $socket ) ) {
Packit Service 64bc36
      my $ret = $socket->sysread( my $buffer, 8192 );
Packit Service 64bc36
      defined $ret or die "Cannot read socket - $!\n";
Packit Service 64bc36
      $ret or last;
Packit Service 64bc36
      STDOUT->syswrite( $buffer );
Packit Service 64bc36
   }
Packit Service 64bc36
}