mirror of
				https://codeberg.org/dwl/dwl-patches.git
				synced 2025-10-26 17:54:17 +00:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
			348dc2ed33
			...
			161c62ae6c
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 161c62ae6c | ||
|   | adda83d5c4 | ||
|   | 1b14ce7fc6 | ||
|   | 07ad746a6f | ||
|   | 12747d1fc6 | 
| @ -46,7 +46,7 @@ If you target the unstable `main` branch, specify that in the `Download` link on | |||||||
|     You may choose to include screenshots (hosted in your patch's subdirectory) in your `README.md`. The process is described [here](https://docs.codeberg.org/markdown/using-images/). |     You may choose to include screenshots (hosted in your patch's subdirectory) in your `README.md`. The process is described [here](https://docs.codeberg.org/markdown/using-images/). | ||||||
| 
 | 
 | ||||||
| 8. Use the Codeberg web interface to send a pull request to [dwl-patches] (NOT to [dwl]) | 8. Use the Codeberg web interface to send a pull request to [dwl-patches] (NOT to [dwl]) | ||||||
| 9. WHEN YOUR PULL REQUEST IS APPROVED, your Codeberg account will also be granted commit access to [dwl-patches]. Once you have write access, you can make direct modifications/upates to your patches instead of pull requests. | 9. WHEN YOUR PULL REQUEST IS APPROVED, your Codeberg account will also be granted commit access to [dwl-patches]. Once you have write access, you can make direct modifications/upates to your patches and you are free to create new patches rather than creating pull requests. | ||||||
| 
 | 
 | ||||||
| Individuals who have made known that they no longer intend to maintain their patches will have commit access to the [dwl-pathces] repository removed. | Individuals who have made known that they no longer intend to maintain their patches will have commit access to the [dwl-pathces] repository removed. | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -13,6 +13,7 @@ slstatus -s | dwl | |||||||
| * pixman | * pixman | ||||||
| 
 | 
 | ||||||
| ### Download | ### Download | ||||||
|  | - [main 2025-07-29](/dwl/dwl-patches/raw/branch/main/patches/bar/bar.patch) | ||||||
| - [0.7](/dwl/dwl-patches/raw/branch/main/patches/bar/bar-0.7.patch) | - [0.7](/dwl/dwl-patches/raw/branch/main/patches/bar/bar-0.7.patch) | ||||||
| - [0.6](/dwl/dwl-patches/raw/branch/main/patches/bar/bar-0.6.patch) | - [0.6](/dwl/dwl-patches/raw/branch/main/patches/bar/bar-0.6.patch) | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										1266
									
								
								patches/bar/bar.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1266
									
								
								patches/bar/bar.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										48
									
								
								patches/better-resize/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								patches/better-resize/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,48 @@ | |||||||
|  | ### Description | ||||||
|  | This patch allows you to configure window resizing more flexibly. | ||||||
|  | It introduces three options with the following possible values: | ||||||
|  | 
 | ||||||
|  | - warp_cursor: | ||||||
|  | ``` | ||||||
|  |    0 - the mouse cursor remains in its original position at the start of the resize. | ||||||
|  |    1 - the cursor is automatically warped to the selected corner before resizing begins. | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | - lock_cursor: | ||||||
|  | ``` | ||||||
|  |    0 - the cursor can move freely during the resize. | ||||||
|  |    1 - the cursor position is completely frozen for the entire duration of the resize. | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | - resize_corner: | ||||||
|  | ``` | ||||||
|  |    0: top-left | ||||||
|  |    1: top-right | ||||||
|  |    2: bottom-left | ||||||
|  |    3: bottom-right | ||||||
|  |    4: selects the corner based on the current mouse quadrant | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ### Demos | ||||||
|  | All demos below use resize_corner = 4: | ||||||
|  | | no warp + no lock | warp + lock | | ||||||
|  | |-|-| | ||||||
|  | |  |  | | ||||||
|  | 
 | ||||||
|  | | no warp + lock | warp + no lock | | ||||||
|  | |-|-| | ||||||
|  | |  |  | | ||||||
|  | 
 | ||||||
|  | ### Known Issues (warp + lock) | ||||||
|  | The combination of warp_cursor and lock_cursor is not recommended without outer gaps. | ||||||
|  | If the selected resize corner aligns exactly with a screen corner, the cursor gets locked there and cannot be moved outward, so resizing only works inward. | ||||||
|  | To resize outward, you must restart the resize operation with the cursor positioned somewhere away from the screen corner. | ||||||
|  | This happens because the locked cursor cannot move past the screen edge, and therefore cannot generate a non-zero delta to resize outward. | ||||||
|  | 
 | ||||||
|  | On multihead setups, if the resize corner is near another screen, the window may switch monitors upon completion of the resize. | ||||||
|  | 
 | ||||||
|  | ### Download | ||||||
|  | - [0.7](/dwl/dwl-patches/raw/branch/main/patches/better-resize/better-resize-0.7.patch) | ||||||
|  | 
 | ||||||
|  | ### Authors | ||||||
|  | - [mmistika](https://codeberg.org/mmistika) | ||||||
							
								
								
									
										107
									
								
								patches/better-resize/better-resize-0.7.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								patches/better-resize/better-resize-0.7.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,107 @@ | |||||||
|  | From f109808140cd6323b3a100663a10e048ae32e3a0 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: mmistika <mistikasoft@gmail.com> | ||||||
|  | Date: Thu, 17 Jul 2025 11:59:18 +0200 | ||||||
|  | Subject: [PATCH] Add configurable window resize | ||||||
|  | 
 | ||||||
|  | Signed-off-by: mmistika <mistikasoft@gmail.com> | ||||||
|  | ---
 | ||||||
|  |  config.def.h | 12 ++++++++++++ | ||||||
|  |  dwl.c        | 45 +++++++++++++++++++++++++++++++++++++-------- | ||||||
|  |  2 files changed, 49 insertions(+), 8 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/config.def.h b/config.def.h
 | ||||||
|  | index 22d2171..e404549 100644
 | ||||||
|  | --- a/config.def.h
 | ||||||
|  | +++ b/config.def.h
 | ||||||
|  | @@ -20,6 +20,18 @@ static const float fullscreen_bg[]         = {0.1f, 0.1f, 0.1f, 1.0f}; /* You ca
 | ||||||
|  |  /* logging */ | ||||||
|  |  static int log_level = WLR_ERROR; | ||||||
|  |   | ||||||
|  | +/* window resizing */
 | ||||||
|  | +/* resize_corner:
 | ||||||
|  | + * 0: top-left
 | ||||||
|  | + * 1: top-right
 | ||||||
|  | + * 2: bottom-left
 | ||||||
|  | + * 3: bottom-right
 | ||||||
|  | + * 4: closest to the cursor
 | ||||||
|  | + */
 | ||||||
|  | +static const int resize_corner = 4;
 | ||||||
|  | +static const int warp_cursor = 1;	/* 1: warp to corner, 0: don’t warp */
 | ||||||
|  | +static const int lock_cursor = 0;	/* 1: lock cursor, 0: don't lock */
 | ||||||
|  | +
 | ||||||
|  |  /* NOTE: ALWAYS keep a rule declared even if you don't use rules (e.g leave at least one example) */ | ||||||
|  |  static const Rule rules[] = { | ||||||
|  |  	/* app_id             title       tags mask     isfloating   monitor */ | ||||||
|  | diff --git a/dwl.c b/dwl.c
 | ||||||
|  | index c717c1d..aacd074 100644
 | ||||||
|  | --- a/dwl.c
 | ||||||
|  | +++ b/dwl.c
 | ||||||
|  | @@ -407,6 +407,7 @@ static KeyboardGroup *kb_group;
 | ||||||
|  |  static unsigned int cursor_mode; | ||||||
|  |  static Client *grabc; | ||||||
|  |  static int grabcx, grabcy; /* client-relative */ | ||||||
|  | +static int rzcorner;
 | ||||||
|  |   | ||||||
|  |  static struct wlr_output_layout *output_layout; | ||||||
|  |  static struct wlr_box sgeom; | ||||||
|  | @@ -1873,8 +1874,24 @@ motionnotify(uint32_t time, struct wlr_input_device *device, double dx, double d
 | ||||||
|  |  			.width = grabc->geom.width, .height = grabc->geom.height}, 1); | ||||||
|  |  		return; | ||||||
|  |  	} else if (cursor_mode == CurResize) { | ||||||
|  | -		resize(grabc, (struct wlr_box){.x = grabc->geom.x, .y = grabc->geom.y,
 | ||||||
|  | -			.width = (int)round(cursor->x) - grabc->geom.x, .height = (int)round(cursor->y) - grabc->geom.y}, 1);
 | ||||||
|  | +		int cdx = (int)round(cursor->x) - grabcx;
 | ||||||
|  | +		int cdy = (int)round(cursor->y) - grabcy;
 | ||||||
|  | +
 | ||||||
|  | +		const struct wlr_box box = {
 | ||||||
|  | +			.x      = grabc->geom.x      + (rzcorner & 1 ? 0   :  cdx),
 | ||||||
|  | +			.y      = grabc->geom.y      + (rzcorner & 2 ? 0   :  cdy),
 | ||||||
|  | +			.width  = grabc->geom.width  + (rzcorner & 1 ? cdx : -cdx),
 | ||||||
|  | +			.height = grabc->geom.height + (rzcorner & 2 ? cdy : -cdy)
 | ||||||
|  | +		};
 | ||||||
|  | +		resize(grabc, box, 1);
 | ||||||
|  | +
 | ||||||
|  | +		if (!lock_cursor) {
 | ||||||
|  | +			grabcx += cdx;
 | ||||||
|  | +			grabcy += cdy;
 | ||||||
|  | +		} else {
 | ||||||
|  | +			wlr_cursor_warp_closest(cursor, NULL, grabcx, grabcy);
 | ||||||
|  | +		}
 | ||||||
|  | +
 | ||||||
|  |  		return; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | @@ -1920,12 +1937,24 @@ moveresize(const Arg *arg)
 | ||||||
|  |  		wlr_cursor_set_xcursor(cursor, cursor_mgr, "fleur"); | ||||||
|  |  		break; | ||||||
|  |  	case CurResize: | ||||||
|  | -		/* Doesn't work for X11 output - the next absolute motion event
 | ||||||
|  | -		 * returns the cursor to where it started */
 | ||||||
|  | -		wlr_cursor_warp_closest(cursor, NULL,
 | ||||||
|  | -				grabc->geom.x + grabc->geom.width,
 | ||||||
|  | -				grabc->geom.y + grabc->geom.height);
 | ||||||
|  | -		wlr_cursor_set_xcursor(cursor, cursor_mgr, "se-resize");
 | ||||||
|  | +		const char *cursors[] = { "nw-resize", "ne-resize", "sw-resize", "se-resize" };
 | ||||||
|  | +
 | ||||||
|  | +		rzcorner = resize_corner;
 | ||||||
|  | +		grabcx = (int)round(cursor->x);
 | ||||||
|  | +		grabcy = (int)round(cursor->y);
 | ||||||
|  | +
 | ||||||
|  | +		if (rzcorner == 4)
 | ||||||
|  | +			/* identify the closest corner index */
 | ||||||
|  | +			rzcorner = (grabcx - grabc->geom.x < grabc->geom.x + grabc->geom.width  - grabcx ? 0 : 1)
 | ||||||
|  | +			         + (grabcy - grabc->geom.y < grabc->geom.y + grabc->geom.height - grabcy ? 0 : 2);
 | ||||||
|  | +
 | ||||||
|  | +		if (warp_cursor) {
 | ||||||
|  | +			grabcx = rzcorner & 1 ? grabc->geom.x + grabc->geom.width  : grabc->geom.x;
 | ||||||
|  | +			grabcy = rzcorner & 2 ? grabc->geom.y + grabc->geom.height : grabc->geom.y;
 | ||||||
|  | +			wlr_cursor_warp_closest(cursor, NULL, grabcx, grabcy);
 | ||||||
|  | +		}
 | ||||||
|  | +
 | ||||||
|  | +		wlr_cursor_set_xcursor(cursor, cursor_mgr, cursors[rzcorner]);
 | ||||||
|  |  		break; | ||||||
|  |  	} | ||||||
|  |  } | ||||||
|  | -- 
 | ||||||
|  | 2.50.1 | ||||||
|  | 
 | ||||||
							
								
								
									
										11
									
								
								patches/disable-keybindings-on-fullscreen-toggle/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								patches/disable-keybindings-on-fullscreen-toggle/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | |||||||
|  | ### Description | ||||||
|  | This patch changes the default behavior of the [disable-keybindings-on-fullscreen](https://codeberg.org/dwl/dwl-patches/src/branch/main/patches/disable-keybindings-on-fullscreen) patch by only taking effect when you explicitly toggle the functionality. | ||||||
|  | You must apply that patch prior to applying this one. | ||||||
|  | 
 | ||||||
|  | ### Download | ||||||
|  | - [git branch](https://github.com/Shringe/dwl/tree/disable-keybindings-on-fullscreen-toggle)  | ||||||
|  | - [0.7](/dwl/dwl-patches/raw/branch/main/patches/disable-keybindings-on-fullscreen-toggle/disable-keybindings-on-fullscreen-toggle-0.7.patch) | ||||||
|  | 
 | ||||||
|  | ### Authors | ||||||
|  | - [Shringe](https://codeberg.org/Shringe) | ||||||
|  | - shringe_ at [dwl Discord](https://discord.gg/jJxZnrGPWN) | ||||||
| @ -0,0 +1,71 @@ | |||||||
|  | From 71809cee0e27f1b3620773e1745afed8023f71c9 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Shringe <dashingkoso@gmail.com> | ||||||
|  | Date: Mon, 23 Jun 2025 18:50:40 -0500 | ||||||
|  | Subject: [PATCH] Implemented functionality for patch | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  config.def.h |  1 + | ||||||
|  |  dwl.c        | 14 ++++++++++++-- | ||||||
|  |  2 files changed, 13 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/config.def.h b/config.def.h
 | ||||||
|  | index 22d2171..dda4ad0 100644
 | ||||||
|  | --- a/config.def.h
 | ||||||
|  | +++ b/config.def.h
 | ||||||
|  | @@ -142,6 +142,7 @@ static const Key keys[] = {
 | ||||||
|  |  	{ MODKEY,                    XKB_KEY_space,      setlayout,      {0} }, | ||||||
|  |  	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_space,      togglefloating, {0} }, | ||||||
|  |  	{ MODKEY,                    XKB_KEY_e,         togglefullscreen, {0} }, | ||||||
|  | +	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_G,         togglefullscreenkeyinhibit, {0} },
 | ||||||
|  |  	{ MODKEY,                    XKB_KEY_0,          view,           {.ui = ~0} }, | ||||||
|  |  	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_parenright, tag,            {.ui = ~0} }, | ||||||
|  |  	{ MODKEY,                    XKB_KEY_comma,      focusmon,       {.i = WLR_DIRECTION_LEFT} }, | ||||||
|  | diff --git a/dwl.c b/dwl.c
 | ||||||
|  | index f11de4b..5deb9c7 100644
 | ||||||
|  | --- a/dwl.c
 | ||||||
|  | +++ b/dwl.c
 | ||||||
|  | @@ -341,6 +341,7 @@ static void tagmon(const Arg *arg);
 | ||||||
|  |  static void tile(Monitor *m); | ||||||
|  |  static void togglefloating(const Arg *arg); | ||||||
|  |  static void togglefullscreen(const Arg *arg); | ||||||
|  | +static void togglefullscreenkeyinhibit(const Arg *arg);
 | ||||||
|  |  static void toggletag(const Arg *arg); | ||||||
|  |  static void toggleview(const Arg *arg); | ||||||
|  |  static void unlocksession(struct wl_listener *listener, void *data); | ||||||
|  | @@ -414,6 +415,8 @@ static struct wlr_box sgeom;
 | ||||||
|  |  static struct wl_list mons; | ||||||
|  |  static Monitor *selmon; | ||||||
|  |   | ||||||
|  | +static int fullscreen_key_inhibit_enabled = 0;
 | ||||||
|  | +
 | ||||||
|  |  #ifdef XWAYLAND | ||||||
|  |  static void activatex11(struct wl_listener *listener, void *data); | ||||||
|  |  static void associatex11(struct wl_listener *listener, void *data); | ||||||
|  | @@ -1583,8 +1586,9 @@ keybinding(uint32_t mods, xkb_keysym_t sym)
 | ||||||
|  |  	for (k = keys; k < END(keys); k++) { | ||||||
|  |  		if (CLEANMASK(mods) == CLEANMASK(k->mod) | ||||||
|  |  				&& sym == k->keysym && k->func) { | ||||||
|  | -			if (c && c->isfullscreen) {
 | ||||||
|  | -				if (k->func == togglefullscreen) {
 | ||||||
|  | +			if (fullscreen_key_inhibit_enabled
 | ||||||
|  | +        && c && c->isfullscreen) {
 | ||||||
|  | +				if (k->func == togglefullscreenkeyinhibit) {
 | ||||||
|  |  					k->func(&k->arg); | ||||||
|  |  					return 1; | ||||||
|  |  				} | ||||||
|  | @@ -2763,6 +2767,12 @@ togglefullscreen(const Arg *arg)
 | ||||||
|  |  		setfullscreen(sel, !sel->isfullscreen); | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +void
 | ||||||
|  | +togglefullscreenkeyinhibit(const Arg *arg)
 | ||||||
|  | +{
 | ||||||
|  | +  fullscreen_key_inhibit_enabled = !fullscreen_key_inhibit_enabled;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  |  void | ||||||
|  |  toggletag(const Arg *arg) | ||||||
|  |  { | ||||||
|  | -- 
 | ||||||
|  | 2.49.0 | ||||||
|  | 
 | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user