mirror of
				https://codeberg.org/dwl/dwl.git
				synced 2025-10-26 17:54:14 +00:00 
			
		
		
		
	inline handlemove/handleresize
This commit is contained in:
		
							parent
							
								
									599bec5583
								
							
						
					
					
						commit
						26714f172a
					
				
							
								
								
									
										38
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								dwl.c
									
									
									
									
									
								
							| @ -101,8 +101,6 @@ static void cursorframe(struct wl_listener *listener, void *data); | ||||
| static void destroynotify(struct wl_listener *listener, void *data); | ||||
| static void focus(Client *c, struct wlr_surface *surface); | ||||
| static void focusnext(const Arg *arg); | ||||
| static void handlemove(uint32_t time); | ||||
| static void handleresize(uint32_t time); | ||||
| static void inputdevice(struct wl_listener *listener, void *data); | ||||
| static bool keybinding(uint32_t mods, xkb_keysym_t sym); | ||||
| static void keypress(struct wl_listener *listener, void *data); | ||||
| @ -379,28 +377,6 @@ focusnext(const Arg *arg) | ||||
| 	wl_list_insert(clients.prev, &c->link); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| handlemove(uint32_t time) | ||||
| { | ||||
| 	/* Move the grabbed client to the new position. */ | ||||
| 	grabbed_client->x = cursor->x - grab_x; | ||||
| 	grabbed_client->y = cursor->y - grab_y; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| handleresize(uint32_t time) | ||||
| { | ||||
| 	/*
 | ||||
| 	 * Note that I took some shortcuts here. In a more fleshed-out compositor, | ||||
| 	 * you'd wait for the client to prepare a buffer at the new size, then | ||||
| 	 * commit any movement that was prepared. | ||||
| 	 */ | ||||
| 	double dx = cursor->x - grab_x; | ||||
| 	double dy = cursor->y - grab_y; | ||||
| 	wlr_xdg_toplevel_set_size(grabbed_client->xdg_surface, | ||||
| 			grab_width + dx, grab_height + dy); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| inputdevice(struct wl_listener *listener, void *data) | ||||
| { | ||||
| @ -525,10 +501,20 @@ motionnotify(uint32_t time) | ||||
| { | ||||
| 	/* If the mode is non-passthrough, delegate to those functions. */ | ||||
| 	if (cursor_mode == CurMove) { | ||||
| 		handlemove(time); | ||||
| 		/* Move the grabbed client to the new position. */ | ||||
| 		grabbed_client->x = cursor->x - grab_x; | ||||
| 		grabbed_client->y = cursor->y - grab_y; | ||||
| 		return; | ||||
| 	} else if (cursor_mode == CurResize) { | ||||
| 		handleresize(time); | ||||
| 		/*
 | ||||
| 		 * Note that I took some shortcuts here. In a more fleshed-out | ||||
| 		 * compositor, you'd wait for the client to prepare a buffer at | ||||
| 		 * the new size, then commit any movement that was prepared. | ||||
| 		 */ | ||||
| 		double dx = cursor->x - grab_x; | ||||
| 		double dy = cursor->y - grab_y; | ||||
| 		wlr_xdg_toplevel_set_size(grabbed_client->xdg_surface, | ||||
| 				grab_width + dx, grab_height + dy); | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Devin J. Pohly
						Devin J. Pohly