mirror of
				https://codeberg.org/dwl/dwl.git
				synced 2025-10-26 17:54:14 +00:00 
			
		
		
		
	add support for cursor-shape-v1
References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/4106
This commit is contained in:
		
							parent
							
								
									0bb1a1cc5c
								
							
						
					
					
						commit
						0e5405610e
					
				
							
								
								
									
										5
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								Makefile
									
									
									
									
									
								
							| @ -16,7 +16,7 @@ LDLIBS    = `$(PKG_CONFIG) --libs $(PKGS)` $(LIBS) | |||||||
| all: dwl | all: dwl | ||||||
| dwl: dwl.o util.o | dwl: dwl.o util.o | ||||||
| 	$(CC) dwl.o util.o $(LDLIBS) $(LDFLAGS) $(DWLCFLAGS) -o $@ | 	$(CC) dwl.o util.o $(LDLIBS) $(LDFLAGS) $(DWLCFLAGS) -o $@ | ||||||
| dwl.o: dwl.c config.mk config.h client.h xdg-shell-protocol.h wlr-layer-shell-unstable-v1-protocol.h | dwl.o: dwl.c config.mk config.h client.h cursor-shape-v1-protocol.h xdg-shell-protocol.h wlr-layer-shell-unstable-v1-protocol.h | ||||||
| util.o: util.c util.h | util.o: util.c util.h | ||||||
| 
 | 
 | ||||||
| # wayland-scanner is a tool which generates C headers and rigging for Wayland
 | # wayland-scanner is a tool which generates C headers and rigging for Wayland
 | ||||||
| @ -31,6 +31,9 @@ xdg-shell-protocol.h: | |||||||
| wlr-layer-shell-unstable-v1-protocol.h: | wlr-layer-shell-unstable-v1-protocol.h: | ||||||
| 	$(WAYLAND_SCANNER) server-header \
 | 	$(WAYLAND_SCANNER) server-header \
 | ||||||
| 		protocols/wlr-layer-shell-unstable-v1.xml $@ | 		protocols/wlr-layer-shell-unstable-v1.xml $@ | ||||||
|  | cursor-shape-v1-protocol.h: | ||||||
|  | 	$(WAYLAND_SCANNER) server-header \
 | ||||||
|  | 		$(WAYLAND_PROTOCOLS)/staging/cursor-shape/cursor-shape-v1.xml $@ | ||||||
| 
 | 
 | ||||||
| config.h: | config.h: | ||||||
| 	cp config.def.h $@ | 	cp config.def.h $@ | ||||||
|  | |||||||
							
								
								
									
										20
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								dwl.c
									
									
									
									
									
								
							| @ -18,6 +18,7 @@ | |||||||
| #include <wlr/render/wlr_renderer.h> | #include <wlr/render/wlr_renderer.h> | ||||||
| #include <wlr/types/wlr_compositor.h> | #include <wlr/types/wlr_compositor.h> | ||||||
| #include <wlr/types/wlr_cursor.h> | #include <wlr/types/wlr_cursor.h> | ||||||
|  | #include <wlr/types/wlr_cursor_shape_v1.h> | ||||||
| #include <wlr/types/wlr_data_control_v1.h> | #include <wlr/types/wlr_data_control_v1.h> | ||||||
| #include <wlr/types/wlr_data_device.h> | #include <wlr/types/wlr_data_device.h> | ||||||
| #include <wlr/types/wlr_drm.h> | #include <wlr/types/wlr_drm.h> | ||||||
| @ -294,6 +295,7 @@ static void requestmonstate(struct wl_listener *listener, void *data); | |||||||
| static void resize(Client *c, struct wlr_box geo, int interact); | static void resize(Client *c, struct wlr_box geo, int interact); | ||||||
| static void run(char *startup_cmd); | static void run(char *startup_cmd); | ||||||
| static void setcursor(struct wl_listener *listener, void *data); | static void setcursor(struct wl_listener *listener, void *data); | ||||||
|  | static void setcursorshape(struct wl_listener *listener, void *data); | ||||||
| static void setfloating(Client *c, int floating); | static void setfloating(Client *c, int floating); | ||||||
| static void setfullscreen(Client *c, int fullscreen); | static void setfullscreen(Client *c, int fullscreen); | ||||||
| static void setgamma(struct wl_listener *listener, void *data); | static void setgamma(struct wl_listener *listener, void *data); | ||||||
| @ -353,6 +355,7 @@ static struct wlr_layer_shell_v1 *layer_shell; | |||||||
| static struct wlr_output_manager_v1 *output_mgr; | static struct wlr_output_manager_v1 *output_mgr; | ||||||
| static struct wlr_gamma_control_manager_v1 *gamma_control_mgr; | static struct wlr_gamma_control_manager_v1 *gamma_control_mgr; | ||||||
| static struct wlr_virtual_keyboard_manager_v1 *virtual_keyboard_mgr; | static struct wlr_virtual_keyboard_manager_v1 *virtual_keyboard_mgr; | ||||||
|  | static struct wlr_cursor_shape_manager_v1 *cursor_shape_mgr; | ||||||
| 
 | 
 | ||||||
| static struct wlr_cursor *cursor; | static struct wlr_cursor *cursor; | ||||||
| static struct wlr_xcursor_manager *cursor_mgr; | static struct wlr_xcursor_manager *cursor_mgr; | ||||||
| @ -2003,6 +2006,20 @@ setcursor(struct wl_listener *listener, void *data) | |||||||
| 				event->hotspot_x, event->hotspot_y); | 				event->hotspot_x, event->hotspot_y); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void | ||||||
|  | setcursorshape(struct wl_listener *listener, void *data) | ||||||
|  | { | ||||||
|  | 	struct wlr_cursor_shape_manager_v1_request_set_shape_event *event = data; | ||||||
|  | 	if (cursor_mode != CurNormal && cursor_mode != CurPressed) | ||||||
|  | 		return; | ||||||
|  | 	/* This can be sent by any client, so we check to make sure this one is
 | ||||||
|  | 	 * actually has pointer focus first. If so, we can tell the cursor to | ||||||
|  | 	 * use the provided cursor shape. */ | ||||||
|  | 	if (event->seat_client == seat->pointer_state.focused_client) | ||||||
|  | 		wlr_cursor_set_xcursor(cursor, cursor_mgr, | ||||||
|  | 							   wlr_cursor_shape_v1_name(event->shape)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void | void | ||||||
| setfloating(Client *c, int floating) | setfloating(Client *c, int floating) | ||||||
| { | { | ||||||
| @ -2286,6 +2303,9 @@ setup(void) | |||||||
| 	LISTEN_STATIC(&cursor->events.axis, axisnotify); | 	LISTEN_STATIC(&cursor->events.axis, axisnotify); | ||||||
| 	LISTEN_STATIC(&cursor->events.frame, cursorframe); | 	LISTEN_STATIC(&cursor->events.frame, cursorframe); | ||||||
| 
 | 
 | ||||||
|  | 	cursor_shape_mgr = wlr_cursor_shape_manager_v1_create(dpy, 1); | ||||||
|  | 	LISTEN_STATIC(&cursor_shape_mgr->events.request_set_shape, setcursorshape); | ||||||
|  | 
 | ||||||
| 	/*
 | 	/*
 | ||||||
| 	 * Configures a seat, which is a single "seat" at which a user sits and | 	 * Configures a seat, which is a single "seat" at which a user sits and | ||||||
| 	 * operates the computer. This conceptually includes up to one keyboard, | 	 * operates the computer. This conceptually includes up to one keyboard, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Leonardo Hernández Hernández
						Leonardo Hernández Hernández