mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 09:44:18 +00:00 
			
		
		
		
	Don't bother waking up when nothing is attached.
This commit is contained in:
		
							
								
								
									
										20
									
								
								server.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								server.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
				
			|||||||
/* $Id: server.c,v 1.86 2008-12-08 16:19:51 nicm Exp $ */
 | 
					/* $Id: server.c,v 1.87 2008-12-13 18:06:08 nicm Exp $ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
					 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
				
			||||||
@@ -54,7 +54,7 @@ void		 server_lost_client(struct client *);
 | 
				
			|||||||
void	 	 server_lost_window(struct window *);
 | 
					void	 	 server_lost_window(struct window *);
 | 
				
			||||||
void		 server_check_redraw(struct client *);
 | 
					void		 server_check_redraw(struct client *);
 | 
				
			||||||
void		 server_check_timers(struct client *);
 | 
					void		 server_check_timers(struct client *);
 | 
				
			||||||
void		 server_update_socket(const char *);
 | 
					int		 server_update_socket(const char *);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Fork new server. */
 | 
					/* Fork new server. */
 | 
				
			||||||
int
 | 
					int
 | 
				
			||||||
@@ -164,7 +164,7 @@ int
 | 
				
			|||||||
server_main(const char *srv_path, int srv_fd)
 | 
					server_main(const char *srv_path, int srv_fd)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct pollfd	*pfds, *pfd;
 | 
						struct pollfd	*pfds, *pfd;
 | 
				
			||||||
	int		 nfds;
 | 
						int		 nfds, xtimeout;
 | 
				
			||||||
	u_int		 i, n;
 | 
						u_int		 i, n;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	siginit();
 | 
						siginit();
 | 
				
			||||||
@@ -185,9 +185,14 @@ server_main(const char *srv_path, int srv_fd)
 | 
				
			|||||||
		server_fill_windows(&pfd);
 | 
							server_fill_windows(&pfd);
 | 
				
			||||||
		server_fill_clients(&pfd);
 | 
							server_fill_clients(&pfd);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* Update socket permissions. */
 | 
				
			||||||
 | 
							xtimeout = INFTIM;
 | 
				
			||||||
 | 
							if (server_update_socket(srv_path) != 0)
 | 
				
			||||||
 | 
								xtimeout = 100;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* Do the poll. */
 | 
							/* Do the poll. */
 | 
				
			||||||
		/* log_debug("polling %d fds", nfds); */
 | 
							/* log_debug("polling %d fds", nfds); */
 | 
				
			||||||
		if ((nfds = poll(pfds, nfds, 100)) == -1) {
 | 
							if ((nfds = poll(pfds, nfds, xtimeout)) == -1) {
 | 
				
			||||||
			if (errno == EAGAIN || errno == EINTR)
 | 
								if (errno == EAGAIN || errno == EINTR)
 | 
				
			||||||
				continue;
 | 
									continue;
 | 
				
			||||||
			fatal("poll failed");
 | 
								fatal("poll failed");
 | 
				
			||||||
@@ -214,9 +219,6 @@ server_main(const char *srv_path, int srv_fd)
 | 
				
			|||||||
		server_handle_windows(&pfd);
 | 
							server_handle_windows(&pfd);
 | 
				
			||||||
		server_handle_clients(&pfd);
 | 
							server_handle_clients(&pfd);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* Update socket permissions. */
 | 
					 | 
				
			||||||
		server_update_socket(srv_path);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		/*
 | 
							/*
 | 
				
			||||||
		 * If we have no sessions and clients left, let's get out
 | 
							 * If we have no sessions and clients left, let's get out
 | 
				
			||||||
		 * of here...
 | 
							 * of here...
 | 
				
			||||||
@@ -676,7 +678,7 @@ server_lost_window(struct window *w)
 | 
				
			|||||||
	recalculate_sizes();
 | 
						recalculate_sizes();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					int
 | 
				
			||||||
server_update_socket(const char *path)
 | 
					server_update_socket(const char *path)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct session	*s;
 | 
						struct session	*s;
 | 
				
			||||||
@@ -700,4 +702,6 @@ server_update_socket(const char *path)
 | 
				
			|||||||
		else
 | 
							else
 | 
				
			||||||
			chmod(path, S_IRUSR|S_IWUSR);
 | 
								chmod(path, S_IRUSR|S_IWUSR);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return (n);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user