mirror of
				https://github.com/tmux/tmux.git
				synced 2025-10-26 12:27:15 +00:00 
			
		
		
		
	Put this back in with the initialisation in the right order.
This commit is contained in:
		
							
								
								
									
										2
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
									
									
									
									
								
							| @@ -35,7 +35,7 @@ SRCS=	attributes.c cfg.c client.c clock.c \ | |||||||
| 	layout-set.c layout-string.c layout.c log.c job.c \ | 	layout-set.c layout-string.c layout.c log.c job.c \ | ||||||
| 	mode-key.c names.c options.c paste.c procname.c \ | 	mode-key.c names.c options.c paste.c procname.c \ | ||||||
| 	resize.c screen-redraw.c screen-write.c screen.c session.c status.c \ | 	resize.c screen-redraw.c screen-write.c screen.c session.c status.c \ | ||||||
| 	server-fn.c server.c server-client.c server-window.c \ | 	signal.c server-fn.c server.c server-client.c server-window.c \ | ||||||
| 	tmux.c tty-keys.c tty-term.c tty.c utf8.c \ | 	tmux.c tty-keys.c tty-term.c tty.c utf8.c \ | ||||||
| 	window-choose.c window-clock.c window-copy.c window.c \ | 	window-choose.c window-clock.c window-copy.c window.c \ | ||||||
| 	xterm-keys.c xmalloc.c | 	xterm-keys.c xmalloc.c | ||||||
|   | |||||||
							
								
								
									
										25
									
								
								client.c
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								client.c
									
									
									
									
									
								
							| @@ -172,35 +172,12 @@ client_update_event(void) | |||||||
| __dead void | __dead void | ||||||
| client_main(void) | client_main(void) | ||||||
| { | { | ||||||
| 	struct event		ev_sigcont, ev_sigterm, ev_sigwinch; |  | ||||||
| 	struct sigaction	sigact; |  | ||||||
|  |  | ||||||
| 	logfile("client"); | 	logfile("client"); | ||||||
|  |  | ||||||
| 	/* Note: event_init() has already been called. */ | 	/* Note: event_init() has already been called. */ | ||||||
|  |  | ||||||
| 	/* Set up signals. */ | 	/* Set up signals. */ | ||||||
| 	memset(&sigact, 0, sizeof sigact); | 	set_signals(client_signal); | ||||||
| 	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(SIGUSR1, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
| 	if (sigaction(SIGUSR2, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
| 	if (sigaction(SIGTSTP, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
|  |  | ||||||
| 	signal_set(&ev_sigcont, SIGCONT, client_signal, NULL); |  | ||||||
| 	signal_add(&ev_sigcont, NULL); |  | ||||||
| 	signal_set(&ev_sigterm, SIGTERM, client_signal, NULL); |  | ||||||
| 	signal_add(&ev_sigterm, NULL); |  | ||||||
| 	signal_set(&ev_sigwinch, SIGWINCH, client_signal, NULL); |  | ||||||
| 	signal_add(&ev_sigwinch, NULL); |  | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * imsg_read in the first client poll loop (before the terminal has | 	 * imsg_read in the first client poll loop (before the terminal has | ||||||
|   | |||||||
| @@ -91,7 +91,7 @@ cmd_pipe_pane_exec(struct cmd *self, struct cmd_ctx *ctx) | |||||||
| 	case 0: | 	case 0: | ||||||
| 		/* Child process. */ | 		/* Child process. */ | ||||||
| 		close(pipe_fd[0]); | 		close(pipe_fd[0]); | ||||||
| 		server_signal_clear(); | 		clear_signals(); | ||||||
|  |  | ||||||
| 		if (dup2(pipe_fd[1], STDIN_FILENO) == -1) | 		if (dup2(pipe_fd[1], STDIN_FILENO) == -1) | ||||||
| 			_exit(1); | 			_exit(1); | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								job.c
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								job.c
									
									
									
									
									
								
							| @@ -149,7 +149,7 @@ job_run(struct job *job) | |||||||
| 	case -1: | 	case -1: | ||||||
| 		return (-1); | 		return (-1); | ||||||
| 	case 0:		/* child */ | 	case 0:		/* child */ | ||||||
| 		server_signal_clear(); | 		clear_signals(); | ||||||
|  |  | ||||||
| 		environ_push(&global_environ); | 		environ_push(&global_environ); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										67
									
								
								server.c
									
									
									
									
									
								
							
							
						
						
									
										67
									
								
								server.c
									
									
									
									
									
								
							| @@ -49,9 +49,6 @@ struct clients	 dead_clients; | |||||||
| int		 server_fd; | int		 server_fd; | ||||||
| int		 server_shutdown; | int		 server_shutdown; | ||||||
| struct event	 server_ev_accept; | 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; | struct event	 server_ev_second; | ||||||
|  |  | ||||||
| int		 server_create_socket(void); | int		 server_create_socket(void); | ||||||
| @@ -141,6 +138,11 @@ server_start(char *path) | |||||||
| 	if (daemon(1, 0) != 0) | 	if (daemon(1, 0) != 0) | ||||||
| 		fatal("daemon failed"); | 		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"); | 	logfile("server"); | ||||||
| 	log_debug("server started, pid %ld", (long) getpid()); | 	log_debug("server started, pid %ld", (long) getpid()); | ||||||
|  |  | ||||||
| @@ -162,8 +164,6 @@ server_start(char *path) | |||||||
| 	log_debug("socket path %s", socket_path); | 	log_debug("socket path %s", socket_path); | ||||||
| 	setproctitle("server (%s)", rpathbuf); | 	setproctitle("server (%s)", rpathbuf); | ||||||
|  |  | ||||||
| 	event_init(); |  | ||||||
|  |  | ||||||
| 	server_fd = server_create_socket(); | 	server_fd = server_create_socket(); | ||||||
| 	server_client_create(pair[1]); | 	server_client_create(pair[1]); | ||||||
|  |  | ||||||
| @@ -202,7 +202,7 @@ server_start(char *path) | |||||||
| 	evtimer_set(&server_ev_second, server_second_callback, NULL); | 	evtimer_set(&server_ev_second, server_second_callback, NULL); | ||||||
| 	evtimer_add(&server_ev_second, &tv); | 	evtimer_add(&server_ev_second, &tv); | ||||||
|  |  | ||||||
| 	server_signal_set(); | 	set_signals(server_signal_callback); | ||||||
| 	server_loop(); | 	server_loop(); | ||||||
| 	exit(0); | 	exit(0); | ||||||
| } | } | ||||||
| @@ -341,61 +341,6 @@ server_accept_callback(int fd, short events, unused void *data) | |||||||
| 	server_client_create(newfd); | 	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. */ | /* Signal handler. */ | ||||||
| /* ARGSUSED */ | /* ARGSUSED */ | ||||||
| void | void | ||||||
|   | |||||||
							
								
								
									
										88
									
								
								signal.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								signal.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | |||||||
|  | /* $Id$ */ | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> | ||||||
|  |  * Copyright (c) 2010 Romain Francoise <rfrancoise@debian.org> | ||||||
|  |  * | ||||||
|  |  * Permission to use, copy, modify, and distribute this software for any | ||||||
|  |  * purpose with or without fee is hereby granted, provided that the above | ||||||
|  |  * copyright notice and this permission notice appear in all copies. | ||||||
|  |  * | ||||||
|  |  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||||
|  |  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||||
|  |  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||||
|  |  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||||
|  |  * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER | ||||||
|  |  * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING | ||||||
|  |  * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include <string.h> | ||||||
|  | #include <signal.h> | ||||||
|  |  | ||||||
|  | #include "tmux.h" | ||||||
|  |  | ||||||
|  | struct event	ev_sigchld; | ||||||
|  | struct event	ev_sigcont; | ||||||
|  | struct event	ev_sigterm; | ||||||
|  | struct event	ev_sigusr1; | ||||||
|  | struct event	ev_sigwinch; | ||||||
|  |  | ||||||
|  | void | ||||||
|  | set_signals(void(*handler)(int, short, unused 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(&ev_sigchld, SIGCHLD, handler, NULL); | ||||||
|  | 	signal_add(&ev_sigchld, NULL); | ||||||
|  | 	signal_set(&ev_sigcont, SIGCONT, handler, NULL); | ||||||
|  | 	signal_add(&ev_sigcont, NULL); | ||||||
|  | 	signal_set(&ev_sigterm, SIGTERM, handler, NULL); | ||||||
|  | 	signal_add(&ev_sigterm, NULL); | ||||||
|  | 	signal_set(&ev_sigusr1, SIGUSR1, handler, NULL); | ||||||
|  | 	signal_add(&ev_sigusr1, NULL); | ||||||
|  | 	signal_set(&ev_sigwinch, SIGWINCH, handler, NULL); | ||||||
|  | 	signal_add(&ev_sigwinch, NULL); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void | ||||||
|  | clear_signals(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"); | ||||||
|  |  | ||||||
|  | 	event_del(&ev_sigchld); | ||||||
|  | 	event_del(&ev_sigcont); | ||||||
|  | 	event_del(&ev_sigterm); | ||||||
|  | 	event_del(&ev_sigusr1); | ||||||
|  | 	event_del(&ev_sigwinch); | ||||||
|  | } | ||||||
							
								
								
									
										75
									
								
								tmux.c
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								tmux.c
									
									
									
									
									
								
							| @@ -18,6 +18,7 @@ | |||||||
|  |  | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #include <sys/stat.h> | #include <sys/stat.h> | ||||||
|  | #include <sys/wait.h> | ||||||
|  |  | ||||||
| #include <errno.h> | #include <errno.h> | ||||||
| #include <event.h> | #include <event.h> | ||||||
| @@ -41,6 +42,8 @@ struct options	 global_s_options;	/* session options */ | |||||||
| struct options	 global_w_options;	/* window options */ | struct options	 global_w_options;	/* window options */ | ||||||
| struct environ	 global_environ; | struct environ	 global_environ; | ||||||
|  |  | ||||||
|  | struct event_base *ev_base; | ||||||
|  |  | ||||||
| int		 debug_level; | int		 debug_level; | ||||||
| time_t		 start_time; | time_t		 start_time; | ||||||
| char		*socket_path; | char		*socket_path; | ||||||
| @@ -58,11 +61,8 @@ char 		*makesockpath(const char *); | |||||||
| __dead void	 shell_exec(const char *, const char *); | __dead void	 shell_exec(const char *, const char *); | ||||||
|  |  | ||||||
| struct imsgbuf	*main_ibuf; | struct imsgbuf	*main_ibuf; | ||||||
| struct event	 main_ev_sigterm; |  | ||||||
| int	         main_exitval; | int	         main_exitval; | ||||||
|  |  | ||||||
| void		 main_set_signals(void); |  | ||||||
| void		 main_clear_signals(void); |  | ||||||
| void		 main_signal(int, short, unused void *); | void		 main_signal(int, short, unused void *); | ||||||
| void		 main_callback(int, short, void *); | void		 main_callback(int, short, void *); | ||||||
| void		 main_dispatch(const char *); | void		 main_dispatch(const char *); | ||||||
| @@ -238,7 +238,6 @@ main(int argc, char **argv) | |||||||
| 	struct keylist		*keylist; | 	struct keylist		*keylist; | ||||||
| 	struct env_data		 envdata; | 	struct env_data		 envdata; | ||||||
| 	struct msg_command_data	 cmddata; | 	struct msg_command_data	 cmddata; | ||||||
| 	struct sigaction	 sigact; |  | ||||||
| 	char			*s, *shellcmd, *path, *label, *home, *cause; | 	char			*s, *shellcmd, *path, *label, *home, *cause; | ||||||
| 	char			 cwd[MAXPATHLEN], **var; | 	char			 cwd[MAXPATHLEN], **var; | ||||||
| 	void			*buf; | 	void			*buf; | ||||||
| @@ -538,24 +537,16 @@ main(int argc, char **argv) | |||||||
| 		exit(1); | 		exit(1); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* Catch SIGCHLD to avoid a zombie when starting the server. */ | 	ev_base = event_init(); | ||||||
| 	memset(&sigact, 0, sizeof sigact); | 	set_signals(main_signal); | ||||||
| 	sigemptyset(&sigact.sa_mask); |  | ||||||
| 	sigact.sa_handler = SIG_IGN; |  | ||||||
| 	if (sigaction(SIGCHLD, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
|  |  | ||||||
| 	/* Initialise the client socket/start the server. */ | 	/* Initialise the client socket/start the server. */ | ||||||
| 	if ((main_ibuf = client_init(path, cmdflags, flags)) == NULL) | 	if ((main_ibuf = client_init(path, cmdflags, flags)) == NULL) | ||||||
| 		exit(1); | 		exit(1); | ||||||
| 	xfree(path); | 	xfree(path); | ||||||
|  |  | ||||||
| 	event_init(); |  | ||||||
|  |  | ||||||
| 	imsg_compose(main_ibuf, msg, PROTOCOL_VERSION, -1, -1, buf, len); | 	imsg_compose(main_ibuf, msg, PROTOCOL_VERSION, -1, -1, buf, len); | ||||||
|  |  | ||||||
| 	main_set_signals(); |  | ||||||
|  |  | ||||||
| 	events = EV_READ; | 	events = EV_READ; | ||||||
| 	if (main_ibuf->w.queued > 0) | 	if (main_ibuf->w.queued > 0) | ||||||
| 		events |= EV_WRITE; | 		events |= EV_WRITE; | ||||||
| @@ -564,65 +555,23 @@ main(int argc, char **argv) | |||||||
| 	main_exitval = 0; | 	main_exitval = 0; | ||||||
| 	event_dispatch(); | 	event_dispatch(); | ||||||
|  |  | ||||||
| 	main_clear_signals(); | 	clear_signals(); | ||||||
|  |  | ||||||
| 	client_main();	/* doesn't return */ | 	client_main();	/* doesn't return */ | ||||||
| } | } | ||||||
|  |  | ||||||
| void |  | ||||||
| main_set_signals(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(SIGUSR1, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
| 	if (sigaction(SIGUSR2, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
| 	if (sigaction(SIGTSTP, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
|  |  | ||||||
| 	signal_set(&main_ev_sigterm, SIGTERM, main_signal, NULL); |  | ||||||
| 	signal_add(&main_ev_sigterm, NULL); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void |  | ||||||
| main_clear_signals(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(SIGUSR1, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
| 	if (sigaction(SIGUSR2, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
| 	if (sigaction(SIGTSTP, &sigact, NULL) != 0) |  | ||||||
| 		fatal("sigaction failed"); |  | ||||||
|  |  | ||||||
| 	event_del(&main_ev_sigterm); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* ARGSUSED */ | /* ARGSUSED */ | ||||||
| void | void | ||||||
| main_signal(int sig, unused short events, unused void *data) | main_signal(int sig, unused short events, unused void *data) | ||||||
| { | { | ||||||
|  | 	int	status; | ||||||
|  |  | ||||||
| 	switch (sig) { | 	switch (sig) { | ||||||
| 	case SIGTERM: | 	case SIGTERM: | ||||||
| 		exit(1); | 		exit(1); | ||||||
|  | 	case SIGCHLD: | ||||||
|  | 		waitpid(WAIT_ANY, &status, WNOHANG); | ||||||
|  | 		break; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -701,7 +650,7 @@ main_dispatch(const char *shellcmd) | |||||||
| 			memcpy(&shelldata, imsg.data, sizeof shelldata); | 			memcpy(&shelldata, imsg.data, sizeof shelldata); | ||||||
| 			shelldata.shell[(sizeof shelldata.shell) - 1] = '\0'; | 			shelldata.shell[(sizeof shelldata.shell) - 1] = '\0'; | ||||||
|  |  | ||||||
| 			main_clear_signals(); | 			clear_signals(); | ||||||
|  |  | ||||||
| 			shell_exec(shelldata.shell, shellcmd); | 			shell_exec(shelldata.shell, shellcmd); | ||||||
| 		default: | 		default: | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								tmux.h
									
									
									
									
									
								
							| @@ -1253,6 +1253,7 @@ extern struct options global_options; | |||||||
| extern struct options global_s_options; | extern struct options global_s_options; | ||||||
| extern struct options global_w_options; | extern struct options global_w_options; | ||||||
| extern struct environ global_environ; | extern struct environ global_environ; | ||||||
|  | extern struct event_base *ev_base; | ||||||
| extern char	*cfg_file; | extern char	*cfg_file; | ||||||
| extern int	 debug_level; | extern int	 debug_level; | ||||||
| extern int	 be_quiet; | extern int	 be_quiet; | ||||||
| @@ -1583,8 +1584,6 @@ const char *key_string_lookup_key(int); | |||||||
| extern struct clients clients; | extern struct clients clients; | ||||||
| extern struct clients dead_clients; | extern struct clients dead_clients; | ||||||
| int	 server_start(char *); | int	 server_start(char *); | ||||||
| void	 server_signal_set(void); |  | ||||||
| void	 server_signal_clear(void); |  | ||||||
| void	 server_update_socket(void); | void	 server_update_socket(void); | ||||||
|  |  | ||||||
| /* server-client.c */ | /* server-client.c */ | ||||||
| @@ -1900,6 +1899,10 @@ void		 window_choose_ready(struct window_pane *, | |||||||
| void		 queue_window_name(struct window *); | void		 queue_window_name(struct window *); | ||||||
| char		*default_window_name(struct window *); | char		*default_window_name(struct window *); | ||||||
|  |  | ||||||
|  | /* signal.c */ | ||||||
|  | void set_signals(void(*handler)(int, short, unused void *)); | ||||||
|  | void clear_signals(void); | ||||||
|  |  | ||||||
| /* session.c */ | /* session.c */ | ||||||
| extern struct sessions sessions; | extern struct sessions sessions; | ||||||
| extern struct sessions dead_sessions; | extern struct sessions dead_sessions; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Nicholas Marriott
					Nicholas Marriott