mirror of
				https://github.com/tmux/tmux.git
				synced 2025-10-26 12:27:15 +00:00 
			
		
		
		
	Rate limit TIOCSWINSZ on a timer to avoid programs getting hammered with
SIGWINCH when the size changes rapidly. To help a problem reported by Rui Pinheiro.
This commit is contained in:
		| @@ -765,12 +765,14 @@ server_client_loop(void) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* Check if pane should be resized. */ | ||||
| void | ||||
| server_client_check_resize(struct window_pane *wp) | ||||
| static void | ||||
| server_client_resize_event(__unused int fd, __unused short events, void *data) | ||||
| { | ||||
| 	struct window_pane	*wp = data; | ||||
| 	struct winsize		 ws; | ||||
|  | ||||
| 	evtimer_del(&wp->resize_timer); | ||||
|  | ||||
| 	if (!(wp->flags & PANE_RESIZE)) | ||||
| 		return; | ||||
|  | ||||
| @@ -784,6 +786,36 @@ server_client_check_resize(struct window_pane *wp) | ||||
| 	wp->flags &= ~PANE_RESIZE; | ||||
| } | ||||
|  | ||||
| /* Check if pane should be resized. */ | ||||
| void | ||||
| server_client_check_resize(struct window_pane *wp) | ||||
| { | ||||
| 	struct timeval	 tv = { .tv_usec = 250000 }; | ||||
|  | ||||
| 	if (!(wp->flags & PANE_RESIZE)) | ||||
| 		return; | ||||
|  | ||||
| 	if (!event_initialized(&wp->resize_timer)) | ||||
| 		evtimer_set(&wp->resize_timer, server_client_resize_event, wp); | ||||
|  | ||||
| 	/* | ||||
| 	 * The first resize should happen immediately, so if the timer is not | ||||
| 	 * running, do it now. | ||||
| 	 */ | ||||
| 	if (!evtimer_pending(&wp->resize_timer, NULL)) | ||||
| 		server_client_resize_event(-1, 0, wp); | ||||
|  | ||||
| 	/* | ||||
| 	 * If the pane is in the alternate screen, let the timer expire and | ||||
| 	 * resize to give the application a chance to redraw. If not, keep | ||||
| 	 * pushing the timer back. | ||||
| 	 */ | ||||
| 	if (wp->saved_grid != NULL && evtimer_pending(&wp->resize_timer, NULL)) | ||||
| 		return; | ||||
| 	evtimer_del(&wp->resize_timer); | ||||
| 	evtimer_add(&wp->resize_timer, &tv); | ||||
| } | ||||
|  | ||||
| /* Check whether pane should be focused. */ | ||||
| void | ||||
| server_client_check_focus(struct window_pane *wp) | ||||
|   | ||||
							
								
								
									
										2
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								tmux.h
									
									
									
									
									
								
							| @@ -894,6 +894,8 @@ struct window_pane { | ||||
| 	int		 fd; | ||||
| 	struct bufferevent *event; | ||||
|  | ||||
| 	struct event	 resize_timer; | ||||
|  | ||||
| 	u_int		 wmark_size; | ||||
| 	u_int		 wmark_hits; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 nicm
					nicm