mirror of
				https://github.com/tmux/tmux.git
				synced 2025-10-26 12:27:15 +00:00 
			
		
		
		
	Braek some bits out of server_fill_client() that aren't really related to
polling into their own function.
This commit is contained in:
		
							
								
								
									
										74
									
								
								server.c
									
									
									
									
									
								
							
							
						
						
									
										74
									
								
								server.c
									
									
									
									
									
								
							| @@ -90,6 +90,7 @@ void		 server_set_title(struct client *); | ||||
| void		 server_check_timers(struct client *); | ||||
| void		 server_lock_server(void); | ||||
| void		 server_lock_sessions(void); | ||||
| void		 server_check_clients(void); | ||||
| void		 server_second_timers(void); | ||||
| int		 server_update_socket(void); | ||||
|  | ||||
| @@ -369,6 +370,9 @@ server_main(int srv_fd) | ||||
| 			sigusr1 = 0; | ||||
| 		} | ||||
|  | ||||
| 		/* Process client actions. */ | ||||
| 		server_check_clients(); | ||||
|  | ||||
| 		/* Initialise pollfd array and add server socket. */ | ||||
| 		server_poll_reset(); | ||||
| 		server_poll_add(srv_fd, POLLIN); | ||||
| @@ -593,18 +597,47 @@ server_handle_windows(void) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* Check clients for redraw and timers. */ | ||||
| void | ||||
| server_check_clients(void) | ||||
| { | ||||
| 	struct client		*c; | ||||
| 	struct window		*w; | ||||
| 	struct window_pane	*wp; | ||||
| 	u_int		 	 i; | ||||
|  | ||||
| 	for (i = 0; i < ARRAY_LENGTH(&clients); i++) { | ||||
| 		c = ARRAY_ITEM(&clients, i); | ||||
| 		if (c == NULL || c->session == NULL) | ||||
| 			continue; | ||||
|  | ||||
| 		server_check_timers(c); | ||||
| 		server_check_redraw(c); | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * Clear any window redraw flags (will have been redrawn as part of | ||||
| 	 * client). | ||||
| 	 */ | ||||
| 	for (i = 0; i < ARRAY_LENGTH(&windows); i++) { | ||||
| 		w = ARRAY_ITEM(&windows, i); | ||||
| 		if (w == NULL) | ||||
| 			continue; | ||||
|  | ||||
| 		w->flags &= ~WINDOW_REDRAW; | ||||
| 		TAILQ_FOREACH(wp, &w->panes, entry) | ||||
| 			wp->flags &= ~PANE_REDRAW; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* Check for general redraw on client. */ | ||||
| void | ||||
| server_check_redraw(struct client *c) | ||||
| { | ||||
| 	struct session		*s; | ||||
| 	struct session		*s = c->session; | ||||
| 	struct window_pane	*wp; | ||||
| 	int		 	 flags, redraw; | ||||
|  | ||||
| 	if (c == NULL || c->session == NULL) | ||||
| 		return; | ||||
| 	s = c->session; | ||||
|  | ||||
| 	flags = c->tty.flags & TTY_FREEZE; | ||||
| 	c->tty.flags &= ~TTY_FREEZE; | ||||
|  | ||||
| @@ -664,15 +697,11 @@ server_set_title(struct client *c) | ||||
| void | ||||
| server_check_timers(struct client *c) | ||||
| { | ||||
| 	struct session	*s; | ||||
| 	struct session	*s = c->session; | ||||
| 	struct job	*job; | ||||
| 	struct timeval	 tv; | ||||
| 	u_int		 interval; | ||||
|  | ||||
| 	if (c == NULL || c->session == NULL) | ||||
| 		return; | ||||
| 	s = c->session; | ||||
|  | ||||
| 	if (gettimeofday(&tv, NULL) != 0) | ||||
| 		fatal("gettimeofday failed"); | ||||
|  | ||||
| @@ -709,18 +738,13 @@ server_check_timers(struct client *c) | ||||
| void | ||||
| server_fill_clients(void) | ||||
| { | ||||
| 	struct client		*c; | ||||
| 	struct window		*w; | ||||
| 	struct window_pane	*wp; | ||||
| 	u_int		 	 i; | ||||
| 	int			 events; | ||||
| 	struct client	*c; | ||||
| 	u_int		 i; | ||||
| 	int		 events; | ||||
|  | ||||
| 	for (i = 0; i < ARRAY_LENGTH(&clients); i++) { | ||||
| 		c = ARRAY_ITEM(&clients, i); | ||||
|  | ||||
| 		server_check_timers(c); | ||||
| 		server_check_redraw(c); | ||||
|  | ||||
| 		if (c != NULL) { | ||||
| 			events = 0; | ||||
| 			if (!(c->flags & CLIENT_BAD)) | ||||
| @@ -738,20 +762,6 @@ server_fill_clients(void) | ||||
| 			server_poll_add(c->tty.fd, events); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * Clear any window redraw flags (will have been redrawn as part of | ||||
| 	 * client). | ||||
| 	 */ | ||||
| 	for (i = 0; i < ARRAY_LENGTH(&windows); i++) { | ||||
| 		w = ARRAY_ITEM(&windows, i); | ||||
| 		if (w == NULL) | ||||
| 			continue; | ||||
|  | ||||
| 		w->flags &= ~WINDOW_REDRAW; | ||||
| 		TAILQ_FOREACH(wp, &w->panes, entry) | ||||
| 			wp->flags &= ~PANE_REDRAW; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* Fill in job fds. */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Nicholas Marriott
					Nicholas Marriott