|  |  |  | @ -231,8 +231,8 @@ static struct cmd_results *cmd_output_background(struct output_config *output, | 
			
		
	
		
			
				
					|  |  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | struct cmd_results *cmd_output(int argc, char **argv) { | 
			
		
	
		
			
				
					|  |  |  |  | 	struct cmd_results *error = NULL; | 
			
		
	
		
			
				
					|  |  |  |  | 	if ((error = checkarg(argc, "output", EXPECTED_AT_LEAST, 1))) { | 
			
		
	
		
			
				
					|  |  |  |  | 	struct cmd_results *error = checkarg(argc, "output", EXPECTED_AT_LEAST, 1); | 
			
		
	
		
			
				
					|  |  |  |  | 	if (error != NULL) { | 
			
		
	
		
			
				
					|  |  |  |  | 		return error; | 
			
		
	
		
			
				
					|  |  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
	
		
			
				
					|  |  |  | @ -275,11 +275,11 @@ struct cmd_results *cmd_output(int argc, char **argv) { | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 	int i = list_seq_find(config->output_configs, output_name_cmp, output->name); | 
			
		
	
		
			
				
					|  |  |  |  | 	if (i >= 0) { | 
			
		
	
		
			
				
					|  |  |  |  | 		// merge existing config
 | 
			
		
	
		
			
				
					|  |  |  |  | 		struct output_config *oc = config->output_configs->items[i]; | 
			
		
	
		
			
				
					|  |  |  |  | 		merge_output_config(oc, output); | 
			
		
	
		
			
				
					|  |  |  |  | 		// Merge existing config
 | 
			
		
	
		
			
				
					|  |  |  |  | 		struct output_config *current = config->output_configs->items[i]; | 
			
		
	
		
			
				
					|  |  |  |  | 		merge_output_config(current, output); | 
			
		
	
		
			
				
					|  |  |  |  | 		free_output_config(output); | 
			
		
	
		
			
				
					|  |  |  |  | 		output = oc; | 
			
		
	
		
			
				
					|  |  |  |  | 		output = current; | 
			
		
	
		
			
				
					|  |  |  |  | 	} else { | 
			
		
	
		
			
				
					|  |  |  |  | 		list_add(config->output_configs, output); | 
			
		
	
		
			
				
					|  |  |  |  | 	} | 
			
		
	
	
		
			
				
					|  |  |  | @ -290,22 +290,26 @@ struct cmd_results *cmd_output(int argc, char **argv) { | 
			
		
	
		
			
				
					|  |  |  |  | 		output->refresh_rate, output->x, output->y, output->scale, | 
			
		
	
		
			
				
					|  |  |  |  | 		output->transform, output->background, output->background_option); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 	if (output->name) { | 
			
		
	
		
			
				
					|  |  |  |  | 		// Try to find the output container and apply configuration now. If
 | 
			
		
	
		
			
				
					|  |  |  |  | 		// this is during startup then there will be no container and config
 | 
			
		
	
		
			
				
					|  |  |  |  | 		// will be applied during normal "new output" event from wlroots.
 | 
			
		
	
		
			
				
					|  |  |  |  | 		swayc_t *cont = NULL; | 
			
		
	
		
			
				
					|  |  |  |  | 		for (int i = 0; i < root_container.children->length; ++i) { | 
			
		
	
		
			
				
					|  |  |  |  | 			cont = root_container.children->items[i]; | 
			
		
	
		
			
				
					|  |  |  |  | 			if (cont->name && ((strcmp(cont->name, output->name) == 0) || | 
			
		
	
		
			
				
					|  |  |  |  | 					(strcmp(output->name, "*") == 0))) { | 
			
		
	
		
			
				
					|  |  |  |  | 				apply_output_config(output, cont); | 
			
		
	
		
			
				
					|  |  |  |  | 	// Try to find the output container and apply configuration now. If
 | 
			
		
	
		
			
				
					|  |  |  |  | 	// this is during startup then there will be no container and config
 | 
			
		
	
		
			
				
					|  |  |  |  | 	// will be applied during normal "new output" event from wlroots.
 | 
			
		
	
		
			
				
					|  |  |  |  | 	char identifier[128]; | 
			
		
	
		
			
				
					|  |  |  |  | 	bool all = strcmp(output->name, "*") == 0; | 
			
		
	
		
			
				
					|  |  |  |  | 	for (int i = 0; i < root_container.children->length; ++i) { | 
			
		
	
		
			
				
					|  |  |  |  | 		swayc_t *cont = root_container.children->items[i]; | 
			
		
	
		
			
				
					|  |  |  |  | 		if (cont->type != C_OUTPUT) { | 
			
		
	
		
			
				
					|  |  |  |  | 			continue; | 
			
		
	
		
			
				
					|  |  |  |  | 		} | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 				if (strcmp(output->name, "*") != 0) { | 
			
		
	
		
			
				
					|  |  |  |  | 					// Stop looking if the output config isn't applicable to all
 | 
			
		
	
		
			
				
					|  |  |  |  | 					// outputs
 | 
			
		
	
		
			
				
					|  |  |  |  | 					break; | 
			
		
	
		
			
				
					|  |  |  |  | 				} | 
			
		
	
		
			
				
					|  |  |  |  | 		output_get_identifier(identifier, sizeof(identifier), cont->sway_output); | 
			
		
	
		
			
				
					|  |  |  |  | 		if (all || strcmp(cont->name, output->name) == 0 || | 
			
		
	
		
			
				
					|  |  |  |  | 				strcmp(identifier, output->name) == 0) { | 
			
		
	
		
			
				
					|  |  |  |  | 			apply_output_config(output, cont); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | 			if (!all) { | 
			
		
	
		
			
				
					|  |  |  |  | 				// Stop looking if the output config isn't applicable to all
 | 
			
		
	
		
			
				
					|  |  |  |  | 				// outputs
 | 
			
		
	
		
			
				
					|  |  |  |  | 				break; | 
			
		
	
		
			
				
					|  |  |  |  | 			} | 
			
		
	
		
			
				
					|  |  |  |  | 		} | 
			
		
	
		
			
				
					|  |  |  |  | 	} | 
			
		
	
	
		
			
				
					|  |  |  | 
 |