From 376a2274ddcf20d61d1f4f5fcdd07e0b8b8e9be2 Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Sat, 27 Mar 2010 21:11:21 -0500 Subject: try to catch more instances of disconnects --- lib/App/Termcast.pm | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/lib/App/Termcast.pm b/lib/App/Termcast.pm index da24a7c..f99ecc4 100644 --- a/lib/App/Termcast.pm +++ b/lib/App/Termcast.pm @@ -100,11 +100,20 @@ sub run { vec($rin, $sockfd, 1) = 1; my ($win, $wout) = ''; vec($win, $sockfd, 1) = 1; + my ($ein, $eout) = ''; + vec($ein, $sockfd, 1) = 1; ReadMode 5; my $guard = Scope::Guard->new(sub { ReadMode 0 }); local $SIG{WINCH} = sub { $self->_got_winch(1) }; while (1) { - my $ready = select($rout = $rin, undef, undef, undef); + my $ready = select($rout = $rin, undef, $eout = $ein, undef); + if (vec($eout, $sockfd, 1)) { + Carp::carp("Lost connection to server ($!), reconnecting..."); + $socket = $self->connect; + vec($rin, $sockfd, 1) = 0; + $sockfd = fileno($socket); + vec($rin, $sockfd, 1) = 1; + } if (vec($rout, fileno(STDIN), 1)) { my $buf; sysread STDIN, $buf, 4096; -- cgit v1.2.3-54-g00ecf