mirror of
				https://codeberg.org/dwl/dwl-patches.git
				synced 2025-10-30 19:44:21 +00:00 
			
		
		
		
	 9c5d5d85f3
			
		
	
	
		9c5d5d85f3
		
			
		
	
	
	
	
		
			
			Eliminated wiki. Individual patches have a README.md explanation in their own subdirectory. Simplified submission of new patches and maintenance of existing patches. Instructions page (README.md autodisplayed) is now at https://codeberg.org/dwl/dwl-patches/
		
			
				
	
	
		
			122 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 98fe302cd240b519c28c886250273854844ab2c7 Mon Sep 17 00:00:00 2001
 | |
| From: Palanix <palanixyt@gmail.com>
 | |
| Date: Fri, 24 Nov 2023 21:16:56 +0100
 | |
| Subject: [PATCH] cweights to allow different size clients in normal layouts
 | |
| 
 | |
| ---
 | |
|  config.def.h |  3 +++
 | |
|  dwl.c        | 32 ++++++++++++++++++++++++++++++--
 | |
|  2 files changed, 33 insertions(+), 2 deletions(-)
 | |
| 
 | |
| diff --git a/config.def.h b/config.def.h
 | |
| index 9009517..27ff521 100644
 | |
| --- a/config.def.h
 | |
| +++ b/config.def.h
 | |
| @@ -128,6 +128,9 @@ static const Key keys[] = {
 | |
|  	{ MODKEY,                    XKB_KEY_d,          incnmaster,     {.i = -1} },
 | |
|  	{ MODKEY,                    XKB_KEY_h,          setmfact,       {.f = -0.05f} },
 | |
|  	{ MODKEY,                    XKB_KEY_l,          setmfact,       {.f = +0.05f} },
 | |
| +	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_H,          setcfact,       {.f = +0.25f} },
 | |
| +	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_L,          setcfact,       {.f = -0.25f} },
 | |
| +	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_K,          setcfact,       {.f = 0.0f} },
 | |
|  	{ MODKEY,                    XKB_KEY_Return,     zoom,           {0} },
 | |
|  	{ MODKEY,                    XKB_KEY_Tab,        view,           {0} },
 | |
|  	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_C,          killclient,     {0} },
 | |
| diff --git a/dwl.c b/dwl.c
 | |
| index fa76db2..9bdb438 100644
 | |
| --- a/dwl.c
 | |
| +++ b/dwl.c
 | |
| @@ -136,6 +136,7 @@ typedef struct {
 | |
|  	uint32_t tags;
 | |
|  	int isfloating, isurgent, isfullscreen;
 | |
|  	uint32_t resize; /* configure serial of a pending resize */
 | |
| +	float cweight;
 | |
|  } Client;
 | |
|  
 | |
|  typedef struct {
 | |
| @@ -301,6 +302,7 @@ static void requeststartdrag(struct wl_listener *listener, void *data);
 | |
|  static void requestmonstate(struct wl_listener *listener, void *data);
 | |
|  static void resize(Client *c, struct wlr_box geo, int interact);
 | |
|  static void run(char *startup_cmd);
 | |
| +static void setcfact(const Arg *arg);
 | |
|  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);
 | |
| @@ -956,6 +958,7 @@ createnotify(struct wl_listener *listener, void *data)
 | |
|  	c = xdg_surface->data = ecalloc(1, sizeof(*c));
 | |
|  	c->surface.xdg = xdg_surface;
 | |
|  	c->bw = borderpx;
 | |
| +	c->cweight = 1.0;
 | |
|  
 | |
|  	wlr_xdg_toplevel_set_wm_capabilities(xdg_surface->toplevel,
 | |
|  			WLR_XDG_TOPLEVEL_WM_CAPABILITIES_FULLSCREEN);
 | |
| @@ -2009,6 +2012,19 @@ run(char *startup_cmd)
 | |
|  	wl_display_run(dpy);
 | |
|  }
 | |
|  
 | |
| +void
 | |
| +setcfact(const Arg *arg)
 | |
| +{
 | |
| +	Client *sel = focustop(selmon);
 | |
| +
 | |
| +	if(!arg || !sel || !selmon->lt[selmon->sellt]->arrange)
 | |
| +		return;
 | |
| +	sel->cweight = (float) (arg->f ? sel->cweight + arg->f : 1.0);
 | |
| +	if (sel->cweight < 0)
 | |
| +		sel->cweight = 0;
 | |
| +	arrange(selmon);
 | |
| +}
 | |
| +
 | |
|  void
 | |
|  setcursor(struct wl_listener *listener, void *data)
 | |
|  {
 | |
| @@ -2468,6 +2484,7 @@ tile(Monitor *m)
 | |
|  {
 | |
|  	unsigned int mw, my, ty;
 | |
|  	int i, n = 0;
 | |
| +	float mweight = 0, tweight = 0;
 | |
|  	Client *c;
 | |
|  
 | |
|  	wl_list_for_each(c, &clients, link)
 | |
| @@ -2480,17 +2497,27 @@ tile(Monitor *m)
 | |
|  		mw = m->nmaster ? ROUND(m->w.width * m->mfact) : 0;
 | |
|  	else
 | |
|  		mw = m->w.width;
 | |
| +	i = 0;
 | |
| +	wl_list_for_each(c, &clients, link){
 | |
| +		if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen)
 | |
| +			continue;
 | |
| +		if (i < m->nmaster)
 | |
| +			mweight += c->cweight;
 | |
| +		else
 | |
| +			tweight += c->cweight;
 | |
| +		i++;
 | |
| +	}
 | |
|  	i = my = ty = 0;
 | |
|  	wl_list_for_each(c, &clients, link) {
 | |
|  		if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen)
 | |
|  			continue;
 | |
|  		if (i < m->nmaster) {
 | |
|  			resize(c, (struct wlr_box){.x = m->w.x, .y = m->w.y + my, .width = mw,
 | |
| -				.height = (m->w.height - my) / (MIN(n, m->nmaster) - i)}, 0);
 | |
| +				.height = (int) ((c->cweight / mweight) * m->w.height)}, 0);
 | |
|  			my += c->geom.height;
 | |
|  		} else {
 | |
|  			resize(c, (struct wlr_box){.x = m->w.x + mw, .y = m->w.y + ty,
 | |
| -				.width = m->w.width - mw, .height = (m->w.height - ty) / (n - i)}, 0);
 | |
| +				.width = m->w.width - mw, .height = (int) ((c->cweight / tweight) * m->w.height) }, 0);
 | |
|  			ty += c->geom.height;
 | |
|  		}
 | |
|  		i++;
 | |
| @@ -2872,6 +2899,7 @@ createnotifyx11(struct wl_listener *listener, void *data)
 | |
|  	c->surface.xwayland = xsurface;
 | |
|  	c->type = X11;
 | |
|  	c->bw = borderpx;
 | |
| +	c->cweight = 1.0;
 | |
|  
 | |
|  	/* Listen to the various events it can emit */
 | |
|  	LISTEN(&xsurface->events.associate, &c->associate, associatex11);
 | |
| -- 
 | |
| 2.43.1
 | |
| 
 |