X-Git-Url: http://scm.dxcluster.org/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FMsg.pm;h=09b0e634e6fc28c6f81ff4faac933e734ceb5109;hb=c7a3cfda9336d765d387e9328f817d1f0e5230d1;hp=f3642d59b79dfabd3bbe0b7f00e7d514421981ba;hpb=251884b14d385d0e00122a238efc3ba992e9f39a;p=spider.git diff --git a/perl/Msg.pm b/perl/Msg.pm index f3642d59..09b0e634 100644 --- a/perl/Msg.pm +++ b/perl/Msg.pm @@ -28,7 +28,8 @@ $now = time; $cnum = 0; $connect_timeout = 5; -$disc_waittime = 3; +$disc_waittime = 1.5; +%conns; our %delqueue; @@ -102,6 +103,12 @@ sub conns return $ref; } +# this is called as a FUNCTION i.e my $conn = Msg::get($call); +sub get +{ + return $conns{shift}; +} + # this is only called by any dependent processes going away unexpectedly sub pid_gone { @@ -276,31 +283,16 @@ sub disconnect $delqueue{$conn} = $conn; # save this connection until everything is finished my $sock = $conn->{sock}; if ($sock) { - - # remove me from the active list - my $call; - if ($call = $conn->{call}) { - my $ref = $conns{$call}; - delete $conns{$call} if $ref && $ref == $conn; + if ($sock->{buffer}) { + my $lth = length $sock->{buffer}; + Mojo::IOLoop->timer($disc_waittime, sub { + dbg("Buffer contained $lth characters, coordinated for $disc_waittime secs, now disconnecting $call") if $dbg; + _close_it($conn); + }); + } else { + dbg("Buffer empty, just close $call") if $dbg; + _close_it($conn); } - - $conn->{delay} = Mojo::IOLoop->delay ( -# Mojo::IOLoop->delay ( - sub { - my $delay = shift; - dbg("before drain $call") if $dbg; - $sock->on(drain => $delay->begin); - 1; - }, - sub { - my $delay = shift; - dbg("before _close_it $call") if $dbg; - _close_it($conn); - 1; - } - ); - $conn->{delay}->wait; - } else { dbg((ref $conn) . " socket missing on $conn->{call}") if $dbg; _close_it($conn);