my @out;
my $count;
-push @out, "Cnum Call Address/Port State Type Dir.";
+push @out, "Cnum Call Address/Port State Type Dir. Module";
foreach my $call (sort keys %Msg::conns) {
my $r = $Msg::conns{$call};
- my $addr = "$r->{peerhost}/$r->{peerport}";
my $c = $call;
+ my $addr;
+
if ($c =~ /^Server\s+(\S+)$/) {
$addr = $1;
$c = "Server";
+ } else {
+ $addr = "$r->{peerhost}/$r->{peerport}";
}
- push @out, sprintf(" %3d %-9s %-27.27s %3s %7s %8s",
+ my $csort = $r->{csort} || '';
+ my $sort = $r->{sort} || '';
+ push @out, sprintf(" %3d %-9s %-27.27s %3s %7s %8s %-8s",
$r->{cnum}, $c,
$addr, $r->{state},
- $r->{csort}, $r->{sort});
+ $csort, $sort, ref $r);
$count++;
}
-push @out, "$count Connections";
+push @out, "$count Connections ($Msg::noconns Allocated)";
return (1, @out);
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 = ();
my $einprogress = eval {EINPROGRESS()};
my $ewouldblock = eval {EWOULDBLOCK()};
$^W = $w;
+$cnum = 0;
+
#
#-----------------------------------------------------------------
csort => 'telnet',
timeval => 60,
blocking => 0,
- cnum => ++$noconns,
+ cnum => (($cnum < 999) ? (++$cnum) : ($cnum = 1)),
};
+ $noconns++;
+
dbg('connll', "Connection created ($noconns)");
return bless $conn, $class;
}
$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");