$conn->{eproc} = $callback;
}
-sub set_eof
+sub set_on_eof
{
my $conn = shift;
my $callback = shift;
- $conn->{sock}->on_eof(sub {$callback});
+ $conn->{sock}->on_eof($callback);
+ $conn->{sock}->on_error($callback);
}
sub set_rproc
}
}
- if (defined($sock)) {
+ if (ref $sock && $sock->isa('AnyEvent::Handle') && exists $sock->{fh}) {
shutdown($sock->{fh}, 2);
$sock->destroy;
+ } else {
+ my $s;
+ $s = "already destroyed" unless exists $sock->{fh};
+ $s ||= ref $sock || $sock || "undefined";
+ dbg("Msg::disconnect trying to disconnect a $s socket") if isdbg('chan');
}
unless ($main::is_win) {
my ($rproc, $eproc) = &{$server_conn->{rproc}} ($conn, $conn->{peerhost} = $peerhost, $conn->{peerport} = $peerport);
dbg("accept $conn->{cnum} from $conn->{peerhost} $conn->{peerport}") if isdbg('connll');
$conn->{sort} = 'Incoming';
+ $conn->{sock}->on_read(sub {$conn->_rcv});
if ($eproc) {
$conn->{eproc} = $eproc;
}
if ($rproc) {
$conn->{rproc} = $rproc;
- $conn->{sock}->on_read(sub {$conn->_rcv});
} else { # Login failed
&{$conn->{eproc}}($conn, undef) if exists $conn->{eproc};
$conn->disconnect();