Ensure that timers are freed and activated when necessary
This commit is contained in:
		
							parent
							
								
									9e4c2ddc47
								
							
						
					
					
						commit
						215a164e57
					
				
					 1 changed files with 31 additions and 7 deletions
				
			
		|  | @ -377,26 +377,50 @@ hexchat_reinit_timers (void) | ||||||
| 	static int lag_check_tag = 0; | 	static int lag_check_tag = 0; | ||||||
| 	static int away_tag = 0; | 	static int away_tag = 0; | ||||||
| 
 | 
 | ||||||
| 	if (prefs.hex_notify_timeout) | 	/* notify timeout */ | ||||||
|  | 	if (prefs.hex_notify_timeout && notify_tag == 0) | ||||||
| 	{ | 	{ | ||||||
| 		notify_tag = fe_timeout_add_seconds (prefs.hex_notify_timeout, | 		notify_tag = fe_timeout_add_seconds (prefs.hex_notify_timeout, | ||||||
| 						     notify_checklist, NULL); | 						     notify_checklist, NULL); | ||||||
| 	} else | 	} | ||||||
|  | 	else if (notify_tag != 0) | ||||||
| 	{ | 	{ | ||||||
| 		fe_timeout_remove (notify_tag); | 		fe_timeout_remove (notify_tag); | ||||||
|  | 		notify_tag = 0; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fe_timeout_remove (away_tag); | 	/* away status tracking */ | ||||||
| 	away_tag = fe_timeout_add_seconds (prefs.hex_away_timeout, away_check, NULL); | 	if (prefs.hex_away_track && away_tag == 0) | ||||||
|  | 	{ | ||||||
|  | 		away_tag = fe_timeout_add_seconds (prefs.hex_away_timeout, away_check, NULL); | ||||||
|  | 	} | ||||||
|  | 	else if (away_tag != 0) | ||||||
|  | 	{ | ||||||
|  | 		fe_timeout_remove (away_tag); | ||||||
|  | 		away_tag = 0; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (prefs.hex_gui_lagometer) | 	/* lag-o-meter */ | ||||||
|  | 	if (prefs.hex_gui_lagometer && lag_check_update_tag == 0) | ||||||
| 	{ | 	{ | ||||||
| 		lag_check_update_tag = fe_timeout_add (500, hexchat_lag_check_update, NULL); | 		lag_check_update_tag = fe_timeout_add (500, hexchat_lag_check_update, NULL); | ||||||
| 		lag_check_tag = fe_timeout_add_seconds (30, hexchat_lag_check, NULL); | 	} | ||||||
| 	} else | 	else if (lag_check_update_tag != 0) | ||||||
| 	{ | 	{ | ||||||
| 		fe_timeout_remove (lag_check_update_tag); | 		fe_timeout_remove (lag_check_update_tag); | ||||||
|  | 		lag_check_update_tag = 0; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	/* network timeouts and lag-o-meter */ | ||||||
|  | 	if ((prefs.hex_net_ping_timeout != 0 || prefs.hex_gui_lagometer) | ||||||
|  | 	    && lag_check_tag == 0) | ||||||
|  | 	{ | ||||||
|  | 		lag_check_tag = fe_timeout_add_seconds (30, hexchat_lag_check, NULL); | ||||||
|  | 	} | ||||||
|  | 	else if (lag_check_tag != 0) | ||||||
|  | 	{ | ||||||
| 		fe_timeout_remove (lag_check_tag); | 		fe_timeout_remove (lag_check_tag); | ||||||
|  | 		lag_check_tag = 0; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue