use just one loop in outputmgrapplyortest()
we do the magic in updatemons()
This commit is contained in:
		
							parent
							
								
									cb01ce9bcf
								
							
						
					
					
						commit
						9b5f0f0fc5
					
				
							
								
								
									
										24
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								dwl.c
									
									
									
									
									
								
							| @ -1631,28 +1631,13 @@ outputmgrapplyortest(struct wlr_output_configuration_v1 *config, int test) | |||||||
| 	struct wlr_output_configuration_head_v1 *config_head; | 	struct wlr_output_configuration_head_v1 *config_head; | ||||||
| 	int ok = 1; | 	int ok = 1; | ||||||
| 
 | 
 | ||||||
| 	/* First disable outputs we need to disable */ |  | ||||||
| 	wl_list_for_each(config_head, &config->heads, link) { |  | ||||||
| 		struct wlr_output *wlr_output = config_head->state.output; |  | ||||||
| 		if (!wlr_output->enabled || config_head->state.enabled) |  | ||||||
| 			continue; |  | ||||||
| 		wlr_output_enable(wlr_output, 0); |  | ||||||
| 		if (test) { |  | ||||||
| 			ok &= wlr_output_test(wlr_output); |  | ||||||
| 			wlr_output_rollback(wlr_output); |  | ||||||
| 		} else { |  | ||||||
| 			ok &= wlr_output_commit(wlr_output); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	/* Then enable outputs that need to */ |  | ||||||
| 	wl_list_for_each(config_head, &config->heads, link) { | 	wl_list_for_each(config_head, &config->heads, link) { | ||||||
| 		struct wlr_output *wlr_output = config_head->state.output; | 		struct wlr_output *wlr_output = config_head->state.output; | ||||||
| 		Monitor *m = wlr_output->data; | 		Monitor *m = wlr_output->data; | ||||||
| 		if (!config_head->state.enabled) |  | ||||||
| 			continue; |  | ||||||
| 
 | 
 | ||||||
| 		wlr_output_enable(wlr_output, 1); | 		wlr_output_enable(wlr_output, config_head->state.enabled); | ||||||
|  | 		if (!config_head->state.enabled) | ||||||
|  | 			goto apply_or_test; | ||||||
| 		if (config_head->state.mode) | 		if (config_head->state.mode) | ||||||
| 			wlr_output_set_mode(wlr_output, config_head->state.mode); | 			wlr_output_set_mode(wlr_output, config_head->state.mode); | ||||||
| 		else | 		else | ||||||
| @ -1669,6 +1654,7 @@ outputmgrapplyortest(struct wlr_output_configuration_v1 *config, int test) | |||||||
| 		wlr_output_set_transform(wlr_output, config_head->state.transform); | 		wlr_output_set_transform(wlr_output, config_head->state.transform); | ||||||
| 		wlr_output_set_scale(wlr_output, config_head->state.scale); | 		wlr_output_set_scale(wlr_output, config_head->state.scale); | ||||||
| 
 | 
 | ||||||
|  | apply_or_test: | ||||||
| 		if (test) { | 		if (test) { | ||||||
| 			ok &= wlr_output_test(wlr_output); | 			ok &= wlr_output_test(wlr_output); | ||||||
| 			wlr_output_rollback(wlr_output); | 			wlr_output_rollback(wlr_output); | ||||||
| @ -1678,7 +1664,7 @@ outputmgrapplyortest(struct wlr_output_configuration_v1 *config, int test) | |||||||
| 			 * we test if that mode does not fail rather than just call wlr_output_commit(). | 			 * we test if that mode does not fail rather than just call wlr_output_commit(). | ||||||
| 			 * We do not test normal modes because (at least in my hardware (@sevz17)) | 			 * We do not test normal modes because (at least in my hardware (@sevz17)) | ||||||
| 			 * wlr_output_test() fails even if that mode can actually be set */ | 			 * wlr_output_test() fails even if that mode can actually be set */ | ||||||
| 			if (!config_head->state.mode) | 			if (!config_head->state.mode && config_head->state.enabled) | ||||||
| 				ok &= (output_ok = wlr_output_test(wlr_output) | 				ok &= (output_ok = wlr_output_test(wlr_output) | ||||||
| 						&& wlr_output_commit(wlr_output)); | 						&& wlr_output_commit(wlr_output)); | ||||||
| 			else | 			else | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user