Allow stopping (via kill -STOP) and "fg" to resume session

This commit is contained in:
Keith Winstein
2012-11-04 13:07:24 -05:00
parent 07b2942945
commit 28ed30c356
2 changed files with 22 additions and 4 deletions
+20 -4
View File
@@ -62,6 +62,21 @@
#include "networktransport.cc" #include "networktransport.cc"
void STMClient::resume( void )
{
/* Restore termios state */
if ( tcsetattr( STDIN_FILENO, TCSANOW, &raw_termios ) < 0 ) {
perror( "tcsetattr" );
exit( 1 );
}
/* Put terminal in application-cursor-key mode */
swrite( STDOUT_FILENO, Terminal::Emulator::open().c_str() );
/* Flag that outer terminal state is unknown */
repaint_requested = true;
}
void STMClient::init( void ) void STMClient::init( void )
{ {
if ( !is_utf8_locale() ) { if ( !is_utf8_locale() ) {
@@ -146,7 +161,6 @@ void STMClient::main_init( void )
sel.add_signal( SIGINT ); sel.add_signal( SIGINT );
sel.add_signal( SIGHUP ); sel.add_signal( SIGHUP );
sel.add_signal( SIGPIPE ); sel.add_signal( SIGPIPE );
sel.add_signal( SIGTSTP );
sel.add_signal( SIGCONT ); sel.add_signal( SIGCONT );
/* get initial window size */ /* get initial window size */
@@ -376,12 +390,14 @@ void STMClient::main( void )
if ( !process_resize() ) { return; } if ( !process_resize() ) { return; }
} }
if ( sel.signal( SIGCONT ) ) {
resume();
}
if ( sel.signal( SIGTERM ) if ( sel.signal( SIGTERM )
|| sel.signal( SIGINT ) || sel.signal( SIGINT )
|| sel.signal( SIGHUP ) || sel.signal( SIGHUP )
|| sel.signal( SIGPIPE ) || sel.signal( SIGPIPE ) ) {
|| sel.signal( SIGTSTP )
|| sel.signal( SIGCONT ) ) {
/* shutdown signal */ /* shutdown signal */
if ( !network->has_remote_addr() ) { if ( !network->has_remote_addr() ) {
break; break;
+2
View File
@@ -74,6 +74,8 @@ private:
return network && ( network->get_remote_state_num() == 0 ); return network && ( network->get_remote_state_num() == 0 );
} }
void resume( void ); /* restore state after SIGCONT */
public: public:
STMClient( const char *s_ip, int s_port, const char *s_key, const char *predict_mode ) STMClient( const char *s_ip, int s_port, const char *s_key, const char *predict_mode )
: ip( s_ip ), port( s_port ), key( s_key ), : ip( s_ip ), port( s_port ), key( s_key ),