X-Git-Url: http://scm.dxcluster.org/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FMsg.pm;h=aa5edc48bd4a8ba454005f3ff8c3e5df5f8fc7cf;hb=503b6b1f503860def06f4e2121b0367e856081cd;hp=1ed5377c20f890238aba810e798f4c54ec5bfeef;hpb=ee8c2e94a865274a859ffc3e57d043e24dcf39df;p=spider.git diff --git a/perl/Msg.pm b/perl/Msg.pm index 1ed5377c..aa5edc48 100644 --- a/perl/Msg.pm +++ b/perl/Msg.pm @@ -16,7 +16,7 @@ use IO::Socket; use DXDebug; use Timer; -use vars qw(%rd_callbacks %wt_callbacks %er_callbacks $rd_handles $wt_handles $er_handles $now %conns $noconns); +use vars qw(%rd_callbacks %wt_callbacks %er_callbacks $rd_handles $wt_handles $er_handles $now %conns $noconns $blocking_supported); %rd_callbacks = (); %wt_callbacks = (); @@ -26,14 +26,19 @@ $wt_handles = IO::Select->new(); $er_handles = IO::Select->new(); $now = time; -my $blocking_supported = 0; BEGIN { # Checks if blocking is supported eval { - require POSIX; POSIX->import(qw (F_SETFL F_GETFL O_NONBLOCK)); + require POSIX; POSIX->import(qw(O_NONBLOCK F_SETFL F_GETFL)) }; - $blocking_supported = 1 unless $@; + if ($@) { + print STDERR "POSIX Blocking *** NOT *** supported $@\n"; + } else { + $blocking_supported = 1; + print STDERR "POSIX Blocking enabled\n"; + } + # import as many of these errno values as are available eval { @@ -155,10 +160,8 @@ sub connect { my $proto = getprotobyname('tcp'); $sock->socket(AF_INET, SOCK_STREAM, $proto) or return undef; - if ($conn->{blocking}) { - blocking($sock, 0); - $conn->{blocking} = 0; - } + blocking($sock, 0); + $conn->{blocking} = 0; my $ip = gethostbyname($to_host); # my $r = $sock->connect($to_port, $ip); @@ -394,6 +397,8 @@ sub new_client { if ($sock) { my $conn = $server_conn->new($server_conn->{rproc}); $conn->{sock} = $sock; + blocking($sock, 0); + $conn->{blocking} = 0; my ($rproc, $eproc) = &{$server_conn->{rproc}} ($conn, $conn->{peerhost} = $sock->peerhost(), $conn->{peerport} = $sock->peerport()); $conn->{sort} = 'Incoming'; if ($eproc) {