Allow stopping (via kill -STOP) and "fg" to resume session
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
@@ -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 ),
|
||||||
|
|||||||
Reference in New Issue
Block a user