@ -36,7 +36,7 @@  
															
														 
														
													
														
															
																 
																 
																
  
																 
																 
																
  
															
														 
														
													
														
															
																 
																 
																# define USAGE \  
																 
																 
																# define USAGE \  
															
														 
														
													
														
															
																 
																 
																	" st  "  VERSION  "  (c) 2010-2012 st engineers \n "  \   
																 
																 
																	" st  "  VERSION  "  (c) 2010-2012 st engineers \n "  \   
															
														 
														
													
														
															
																 
																 
																	" usage: st [-t title] [-c class] [-w windowid] [-v] [-e command...] \n "   
																 
																 
																 
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																	" usage: st [-t title] [-c class] [-w windowid] [-v] [-f file] [- e command...] \n "   
															
														 
														
													
														
															
																 
																 
																
  
																 
																 
																
  
															
														 
														
													
														
															
																 
																 
																/* XEMBED messages */  
																 
																 
																/* XEMBED messages */  
															
														 
														
													
														
															
																 
																 
																# define XEMBED_FOCUS_IN  4  
																 
																 
																# define XEMBED_FOCUS_IN  4  
															
														 
														
													
												
													
														
															
																
																	
																		
																			 
																		 
																	
																	
																		
																			 
																		 
																	
																	
																 
																@ -342,7 +342,9 @@ static STREscape strescseq;  
															
														 
														
													
														
															
																 
																 
																static  int  cmdfd ;  
																 
																 
																static  int  cmdfd ;  
															
														 
														
													
														
															
																 
																 
																static  pid_t  pid ;  
																 
																 
																static  pid_t  pid ;  
															
														 
														
													
														
															
																 
																 
																static  Selection  sel ;  
																 
																 
																static  Selection  sel ;  
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																static  FILE  * fileio ;  
															
														 
														
													
														
															
																 
																 
																static  char  * * opt_cmd   =  NULL ;  
																 
																 
																static  char  * * opt_cmd   =  NULL ;  
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																static  char  * opt_io     =  NULL ;  
															
														 
														
													
														
															
																 
																 
																static  char  * opt_title  =  NULL ;  
																 
																 
																static  char  * opt_title  =  NULL ;  
															
														 
														
													
														
															
																 
																 
																static  char  * opt_embed  =  NULL ;  
																 
																 
																static  char  * opt_embed  =  NULL ;  
															
														 
														
													
														
															
																 
																 
																static  char  * opt_class  =  NULL ;  
																 
																 
																static  char  * opt_class  =  NULL ;  
															
														 
														
													
												
													
														
															
																
																	
																		
																			 
																		 
																	
																	
																		
																			 
																		 
																	
																	
																 
																@ -776,6 +778,10 @@ ttynew(void) {  
															
														 
														
													
														
															
																 
																 
																		close ( s ) ;   
																 
																 
																		close ( s ) ;   
															
														 
														
													
														
															
																 
																 
																		cmdfd  =  m ;   
																 
																 
																		cmdfd  =  m ;   
															
														 
														
													
														
															
																 
																 
																		signal ( SIGCHLD ,  sigchld ) ;   
																 
																 
																		signal ( SIGCHLD ,  sigchld ) ;   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																		if  ( opt_io  & &  ! ( fileio  =  fopen ( opt_io ,  " w " ) ) )  {   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																			fprintf ( stderr ,  " Error opening %s:%s " ,   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																				opt_io ,  strerror ( errno ) ) ;   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																		}   
															
														 
														
													
														
															
																 
																 
																	}   
																 
																 
																	}   
															
														 
														
													
														
															
																 
																 
																}  
																 
																 
																}  
															
														 
														
													
														
															
																 
																 
																
  
																 
																 
																
  
															
														 
														
													
												
													
														
															
																
																	
																		
																			 
																		 
																	
																	
																		
																			 
																		 
																	
																	
																 
																@ -1534,6 +1540,9 @@ tputtab(bool forward) {  
															
														 
														
													
														
															
																 
																 
																void  
																 
																 
																void  
															
														 
														
													
														
															
																 
																 
																tputc ( char  * c )  {  
																 
																 
																tputc ( char  * c )  {  
															
														 
														
													
														
															
																 
																 
																	char  ascii  =  * c ;   
																 
																 
																	char  ascii  =  * c ;   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																
  
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																	if  ( fileio )   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																		putc ( ascii ,  fileio ) ;   
															
														 
														
													
														
															
																 
																 
																	if ( term . esc  &  ESC_START )  {   
																 
																 
																	if ( term . esc  &  ESC_START )  {   
															
														 
														
													
														
															
																 
																 
																		if ( term . esc  &  ESC_CSI )  {   
																 
																 
																		if ( term . esc  &  ESC_CSI )  {   
															
														 
														
													
														
															
																 
																 
																			csiescseq . buf [ csiescseq . len + + ]  =  ascii ;   
																 
																 
																			csiescseq . buf [ csiescseq . len + + ]  =  ascii ;   
															
														 
														
													
												
													
														
															
																
																	
																		
																			 
																		 
																	
																	
																		
																			 
																		 
																	
																	
																 
																@ -2269,6 +2278,9 @@ main(int argc, char *argv[]) {  
															
														 
														
													
														
															
																 
																 
																		case  ' w ' :   
																 
																 
																		case  ' w ' :   
															
														 
														
													
														
															
																 
																 
																			if ( + + i  <  argc )  opt_embed  =  argv [ i ] ;   
																 
																 
																			if ( + + i  <  argc )  opt_embed  =  argv [ i ] ;   
															
														 
														
													
														
															
																 
																 
																			break ;   
																 
																 
																			break ;   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																		case  ' f ' :   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																			if  ( + + i  <  argc )  opt_io  =  argv [ i ] ;   
															
														 
														
													
														
															
																 
																 
																 
																 
																 
																			break ;   
															
														 
														
													
														
															
																 
																 
																		case  ' e ' :   
																 
																 
																		case  ' e ' :   
															
														 
														
													
														
															
																 
																 
																			/* eat every remaining arguments */   
																 
																 
																			/* eat every remaining arguments */   
															
														 
														
													
														
															
																 
																 
																			if ( + + i  <  argc )  opt_cmd  =  & argv [ i ] ;   
																 
																 
																			if ( + + i  <  argc )  opt_cmd  =  & argv [ i ] ;