mirror of
				https://github.com/labwc/labwc.git
				synced 2025-11-03 09:01:51 -05:00 
			
		
		
		
	seat: support WLR_{WL,X11}_OUTPUTS >= 2
When running nested in X11 or a wlroots compositor with the respective environment variables WLR_X11_OUTPUTS or WLR_WL_OUTPUTS set to value >= 2, cursors need to be mapped to the respective outputs. Closes issue #196 Suggested-by: @Consolatis Written-by: @johanmalm
This commit is contained in:
		
							parent
							
								
									2b82bdcdb7
								
							
						
					
					
						commit
						cef9723505
					
				
					 1 changed files with 23 additions and 4 deletions
				
			
		
							
								
								
									
										27
									
								
								src/seat.c
									
										
									
									
									
								
							
							
						
						
									
										27
									
								
								src/seat.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -112,13 +112,33 @@ configure_libinput(struct wlr_input_device *wlr_input_device)
 | 
			
		|||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static struct wlr_output *
 | 
			
		||||
output_by_name(struct server *server, const char *name)
 | 
			
		||||
{
 | 
			
		||||
	struct output *output;
 | 
			
		||||
	wl_list_for_each(output, &server->outputs, link) {
 | 
			
		||||
		if (!strcasecmp(output->wlr_output->name, name)) {
 | 
			
		||||
			return output->wlr_output;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	return NULL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
new_pointer(struct seat *seat, struct input *input)
 | 
			
		||||
{
 | 
			
		||||
	if (wlr_input_device_is_libinput(input->wlr_input_device)) {
 | 
			
		||||
		configure_libinput(input->wlr_input_device);
 | 
			
		||||
	struct wlr_input_device *dev = input->wlr_input_device;
 | 
			
		||||
	if (wlr_input_device_is_libinput(dev)) {
 | 
			
		||||
		configure_libinput(dev);
 | 
			
		||||
	}
 | 
			
		||||
	wlr_cursor_attach_input_device(seat->cursor, input->wlr_input_device);
 | 
			
		||||
	wlr_cursor_attach_input_device(seat->cursor, dev);
 | 
			
		||||
 | 
			
		||||
	/* In support of running with WLR_WL_OUTPUTS set to >=2 */
 | 
			
		||||
	wlr_log(WLR_INFO, "map pointer to output %s\n", dev->output_name);
 | 
			
		||||
	struct wlr_output *output =
 | 
			
		||||
		output_by_name(seat->server, dev->output_name);
 | 
			
		||||
	wlr_cursor_map_input_to_output(seat->cursor, dev, output);
 | 
			
		||||
	wlr_cursor_map_input_to_region(seat->cursor, dev, NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
| 
						 | 
				
			
			@ -227,7 +247,6 @@ seat_init(struct server *server)
 | 
			
		|||
		&seat->idle_inhibitor_create);
 | 
			
		||||
	seat->idle_inhibitor_create.notify = new_idle_inhibitor;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	seat->cursor = wlr_cursor_create();
 | 
			
		||||
	if (!seat->cursor) {
 | 
			
		||||
		wlr_log(WLR_ERROR, "unable to create cursor");
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue