X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FMsg.pm;h=3b96c812e502b51b16f5b6a493cbae14aa3e4822;hb=6374fb31da62987e676244c38eb6cf73c81bf891;hp=6e2082e55ca86bcbaf1f1d221bd87625fb621eef;hpb=7f13dbae516120247c76b132354204cd66ba4515;p=spider.git diff --git a/perl/Msg.pm b/perl/Msg.pm index 6e2082e5..3b96c812 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 $blocking_supported); +use vars qw(%rd_callbacks %wt_callbacks %er_callbacks $rd_handles $wt_handles $er_handles $now %conns $noconns $blocking_supported $cnum); %rd_callbacks = (); %wt_callbacks = (); @@ -53,6 +53,8 @@ my $eagain = eval {EAGAIN()}; my $einprogress = eval {EINPROGRESS()}; my $ewouldblock = eval {EWOULDBLOCK()}; $^W = $w; +$cnum = 0; + # #----------------------------------------------------------------- @@ -73,9 +75,11 @@ sub new csort => 'telnet', timeval => 60, blocking => 0, - cnum => ++$noconns, + cnum => (($cnum < 999) ? (++$cnum) : ($cnum = 1)), }; + $noconns++; + dbg('connll', "Connection created ($noconns)"); return bless $conn, $class; } @@ -119,7 +123,7 @@ sub conns $call = $pkg->{call} unless $call; return undef unless $call; dbg('connll', "changing $pkg->{call} to $call") if exists $pkg->{call} && $call ne $pkg->{call}; - delete $conns{$pkg->{call}} if $pkg->{call} ne $call; + delete $conns{$pkg->{call}} if exists $pkg->{call} && exists $conns{$pkg->{call}} && $pkg->{call} ne $call; $pkg->{call} = $call; $ref = $conns{$call} = $pkg; dbg('connll', "Connection $pkg->{cnum} $call stored");