mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-03 16:46:18 +00:00 
			
		
		
		
	Put this back in with the initialisation in the right order.
This commit is contained in:
		
							
								
								
									
										67
									
								
								server.c
									
									
									
									
									
								
							
							
						
						
									
										67
									
								
								server.c
									
									
									
									
									
								
							@@ -49,9 +49,6 @@ struct clients	 dead_clients;
 | 
			
		||||
int		 server_fd;
 | 
			
		||||
int		 server_shutdown;
 | 
			
		||||
struct event	 server_ev_accept;
 | 
			
		||||
struct event	 server_ev_sigterm;
 | 
			
		||||
struct event	 server_ev_sigusr1;
 | 
			
		||||
struct event	 server_ev_sigchld;
 | 
			
		||||
struct event	 server_ev_second;
 | 
			
		||||
 | 
			
		||||
int		 server_create_socket(void);
 | 
			
		||||
@@ -141,6 +138,11 @@ server_start(char *path)
 | 
			
		||||
	if (daemon(1, 0) != 0)
 | 
			
		||||
		fatal("daemon failed");
 | 
			
		||||
 | 
			
		||||
	/* event_init() was called in our parent, need to reinit. */
 | 
			
		||||
	if (event_reinit(ev_base) != 0)
 | 
			
		||||
		fatal("event_reinit failed");
 | 
			
		||||
	clear_signals();
 | 
			
		||||
 | 
			
		||||
	logfile("server");
 | 
			
		||||
	log_debug("server started, pid %ld", (long) getpid());
 | 
			
		||||
 | 
			
		||||
@@ -162,8 +164,6 @@ server_start(char *path)
 | 
			
		||||
	log_debug("socket path %s", socket_path);
 | 
			
		||||
	setproctitle("server (%s)", rpathbuf);
 | 
			
		||||
 | 
			
		||||
	event_init();
 | 
			
		||||
 | 
			
		||||
	server_fd = server_create_socket();
 | 
			
		||||
	server_client_create(pair[1]);
 | 
			
		||||
 | 
			
		||||
@@ -202,7 +202,7 @@ server_start(char *path)
 | 
			
		||||
	evtimer_set(&server_ev_second, server_second_callback, NULL);
 | 
			
		||||
	evtimer_add(&server_ev_second, &tv);
 | 
			
		||||
 | 
			
		||||
	server_signal_set();
 | 
			
		||||
	set_signals(server_signal_callback);
 | 
			
		||||
	server_loop();
 | 
			
		||||
	exit(0);
 | 
			
		||||
}
 | 
			
		||||
@@ -341,61 +341,6 @@ server_accept_callback(int fd, short events, unused void *data)
 | 
			
		||||
	server_client_create(newfd);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Set up server signal handling. */
 | 
			
		||||
void
 | 
			
		||||
server_signal_set(void)
 | 
			
		||||
{
 | 
			
		||||
	struct sigaction	 sigact;
 | 
			
		||||
 | 
			
		||||
	memset(&sigact, 0, sizeof sigact);
 | 
			
		||||
	sigemptyset(&sigact.sa_mask);
 | 
			
		||||
	sigact.sa_flags = SA_RESTART;
 | 
			
		||||
	sigact.sa_handler = SIG_IGN;
 | 
			
		||||
	if (sigaction(SIGINT, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGPIPE, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGUSR2, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGTSTP, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGHUP, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
 | 
			
		||||
	signal_set(&server_ev_sigchld, SIGCHLD, server_signal_callback, NULL);
 | 
			
		||||
	signal_add(&server_ev_sigchld, NULL);
 | 
			
		||||
	signal_set(&server_ev_sigterm, SIGTERM, server_signal_callback, NULL);
 | 
			
		||||
	signal_add(&server_ev_sigterm, NULL);
 | 
			
		||||
	signal_set(&server_ev_sigusr1, SIGUSR1, server_signal_callback, NULL);
 | 
			
		||||
	signal_add(&server_ev_sigusr1, NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Destroy server signal events. */
 | 
			
		||||
void
 | 
			
		||||
server_signal_clear(void)
 | 
			
		||||
{
 | 
			
		||||
	struct sigaction	 sigact;
 | 
			
		||||
 | 
			
		||||
	memset(&sigact, 0, sizeof sigact);
 | 
			
		||||
	sigemptyset(&sigact.sa_mask);
 | 
			
		||||
	sigact.sa_flags = SA_RESTART;
 | 
			
		||||
	sigact.sa_handler = SIG_DFL;
 | 
			
		||||
	if (sigaction(SIGINT, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGPIPE, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGUSR2, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGTSTP, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
	if (sigaction(SIGHUP, &sigact, NULL) != 0)
 | 
			
		||||
		fatal("sigaction failed");
 | 
			
		||||
 | 
			
		||||
	signal_del(&server_ev_sigchld);
 | 
			
		||||
	signal_del(&server_ev_sigterm);
 | 
			
		||||
	signal_del(&server_ev_sigusr1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Signal handler. */
 | 
			
		||||
/* ARGSUSED */
 | 
			
		||||
void
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user