mirror of
				https://codeberg.org/dwl/dwl.git
				synced 2025-10-26 17:54:14 +00:00 
			
		
		
		
	Merge remote-tracking branch 'upstream/main' into wlroots-next
This commit is contained in:
		
						commit
						733754bb06
					
				| @ -2,14 +2,13 @@ | ||||
| static const int sloppyfocus               = 1;  /* focus follows mouse */ | ||||
| static const int bypass_surface_visibility = 0;  /* 1 means idle inhibitors will disable idle tracking even if it's surface isn't visible  */ | ||||
| static const unsigned int borderpx         = 1;  /* border pixel of windows */ | ||||
| static const float rootcolor[]             = {0.3, 0.3, 0.3, 1.0}; | ||||
| static const float bordercolor[]           = {0.5, 0.5, 0.5, 1.0}; | ||||
| static const float focuscolor[]            = {1.0, 0.0, 0.0, 1.0}; | ||||
| /* To conform the xdg-protocol, set the alpha to zero to restore the old behavior */ | ||||
| static const float fullscreen_bg[]         = {0.1, 0.1, 0.1, 1.0}; | ||||
| 
 | ||||
| /* tagging */ | ||||
| static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" }; | ||||
| /* tagging - tagcount must be no greater than 31 */ | ||||
| static const int tagcount = 9; | ||||
| 
 | ||||
| static const Rule rules[] = { | ||||
| 	/* app_id     title       tags mask     isfloating   monitor */ | ||||
| @ -31,7 +30,7 @@ static const Layout layouts[] = { | ||||
| static const MonitorRule monrules[] = { | ||||
| 	/* name       mfact nmaster scale layout       rotate/reflect                x    y */ | ||||
| 	/* example of a HiDPI laptop monitor:
 | ||||
| 	{ "eDP-1",    0.5,  1,      2,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL    -1,  -1 }, | ||||
| 	{ "eDP-1",    0.5,  1,      2,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL,   -1,  -1 }, | ||||
| 	*/ | ||||
| 	/* defaults */ | ||||
| 	{ NULL,       0.55, 1,      1,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL,   -1,  -1 }, | ||||
|  | ||||
							
								
								
									
										51
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										51
									
								
								dwl.c
									
									
									
									
									
								
							| @ -70,7 +70,7 @@ | ||||
| #define VISIBLEON(C, M)         ((M) && (C)->mon == (M) && ((C)->tags & (M)->tagset[(M)->seltags])) | ||||
| #define LENGTH(X)               (sizeof X / sizeof X[0]) | ||||
| #define END(A)                  ((A) + LENGTH(A)) | ||||
| #define TAGMASK                 ((1 << LENGTH(tags)) - 1) | ||||
| #define TAGMASK                 ((1u << tagcount) - 1) | ||||
| #define LISTEN(E, L, H)         wl_signal_add((E), ((L)->notify = (H), (L))) | ||||
| #define IDLE_NOTIFY_ACTIVITY    wlr_idle_notify_activity(idle, seat), wlr_idle_notifier_v1_notify_activity(idle_notifier, seat) | ||||
| 
 | ||||
| @ -85,7 +85,7 @@ enum { NetWMWindowTypeDialog, NetWMWindowTypeSplash, NetWMWindowTypeToolbar, | ||||
| 
 | ||||
| typedef union { | ||||
| 	int i; | ||||
| 	unsigned int ui; | ||||
| 	uint32_t ui; | ||||
| 	float f; | ||||
| 	const void *v; | ||||
| } Arg; | ||||
| @ -126,7 +126,7 @@ typedef struct { | ||||
| 	struct wl_listener set_hints; | ||||
| #endif | ||||
| 	unsigned int bw; | ||||
| 	unsigned int tags; | ||||
| 	uint32_t tags; | ||||
| 	int isfloating, isurgent, isfullscreen; | ||||
| 	uint32_t resize; /* configure serial of a pending resize */ | ||||
| } Client; | ||||
| @ -191,9 +191,10 @@ struct Monitor { | ||||
| 	const Layout *lt[2]; | ||||
| 	unsigned int seltags; | ||||
| 	unsigned int sellt; | ||||
| 	unsigned int tagset[2]; | ||||
| 	uint32_t tagset[2]; | ||||
| 	double mfact; | ||||
| 	int nmaster; | ||||
| 	char ltsymbol[16]; | ||||
| }; | ||||
| 
 | ||||
| typedef struct { | ||||
| @ -209,7 +210,7 @@ typedef struct { | ||||
| typedef struct { | ||||
| 	const char *id; | ||||
| 	const char *title; | ||||
| 	unsigned int tags; | ||||
| 	uint32_t tags; | ||||
| 	int isfloating; | ||||
| 	int monitor; | ||||
| } Rule; | ||||
| @ -297,7 +298,7 @@ static void setfloating(Client *c, int floating); | ||||
| static void setfullscreen(Client *c, int fullscreen); | ||||
| static void setlayout(const Arg *arg); | ||||
| static void setmfact(const Arg *arg); | ||||
| static void setmon(Client *c, Monitor *m, unsigned int newtags); | ||||
| static void setmon(Client *c, Monitor *m, uint32_t newtags); | ||||
| static void setpsel(struct wl_listener *listener, void *data); | ||||
| static void setsel(struct wl_listener *listener, void *data); | ||||
| static void setup(void); | ||||
| @ -416,9 +417,6 @@ static Atom netatom[NetLast]; | ||||
| /* attempt to encapsulate suck into one file */ | ||||
| #include "client.h" | ||||
| 
 | ||||
| /* compile-time check if all tags fit into an unsigned int bit array. */ | ||||
| struct NumTags { char limitexceeded[LENGTH(tags) > 31 ? -1 : 1]; }; | ||||
| 
 | ||||
| /* function implementations */ | ||||
| void | ||||
| applybounds(Client *c, struct wlr_box *bbox) | ||||
| @ -429,8 +427,8 @@ applybounds(Client *c, struct wlr_box *bbox) | ||||
| 		/* try to set size hints */ | ||||
| 		c->geom.width = MAX(min.width + (2 * (int)c->bw), c->geom.width); | ||||
| 		c->geom.height = MAX(min.height + (2 * (int)c->bw), c->geom.height); | ||||
| 		/* Some clients set them max size to INT_MAX, which does not violates
 | ||||
| 		 * the protocol but its innecesary, they can set them max size to zero. */ | ||||
| 		/* Some clients set their max size to INT_MAX, which does not violate the
 | ||||
| 		 * protocol but it's unnecesary, as they can set their max size to zero. */ | ||||
| 		if (max.width > 0 && !(2 * c->bw > INT_MAX - max.width)) /* Checks for overflow */ | ||||
| 			c->geom.width = MIN(max.width + (2 * c->bw), c->geom.width); | ||||
| 		if (max.height > 0 && !(2 * c->bw > INT_MAX - max.height)) /* Checks for overflow */ | ||||
| @ -452,7 +450,7 @@ applyrules(Client *c) | ||||
| { | ||||
| 	/* rule matching */ | ||||
| 	const char *appid, *title; | ||||
| 	unsigned int i, newtags = 0; | ||||
| 	uint32_t i, newtags = 0; | ||||
| 	const Rule *r; | ||||
| 	Monitor *mon = selmon, *m; | ||||
| 
 | ||||
| @ -488,7 +486,9 @@ arrange(Monitor *m) | ||||
| 	wlr_scene_node_set_enabled(&m->fullscreen_bg->node, | ||||
| 			(c = focustop(m)) && c->isfullscreen); | ||||
| 
 | ||||
| 	if (m && m->lt[m->sellt]->arrange) | ||||
| 	strncpy(m->ltsymbol, m->lt[m->sellt]->symbol, LENGTH(m->ltsymbol)); | ||||
| 
 | ||||
| 	if (m->lt[m->sellt]->arrange) | ||||
| 		m->lt[m->sellt]->arrange(m); | ||||
| 	motionnotify(0); | ||||
| 	checkidleinhibitor(NULL); | ||||
| @ -638,13 +638,13 @@ chvt(const Arg *arg) | ||||
| void | ||||
| checkidleinhibitor(struct wlr_surface *exclude) | ||||
| { | ||||
| 	int inhibited = 0; | ||||
| 	int inhibited = 0, unused_lx, unused_ly; | ||||
| 	struct wlr_idle_inhibitor_v1 *inhibitor; | ||||
| 	wl_list_for_each(inhibitor, &idle_inhibit_mgr->inhibitors, link) { | ||||
| 		struct wlr_surface *surface = wlr_surface_get_root_surface(inhibitor->surface); | ||||
| 		struct wlr_scene_tree *tree = surface->data; | ||||
| 		if (exclude != surface && (bypass_surface_visibility || (!tree | ||||
| 				|| tree->node.enabled))) { | ||||
| 				|| wlr_scene_node_coords(&tree->node, &unused_lx, &unused_ly)))) { | ||||
| 			inhibited = 1; | ||||
| 			break; | ||||
| 		} | ||||
| @ -978,6 +978,7 @@ createmon(struct wl_listener *listener, void *data) | ||||
| 		wlr_output_layout_add_auto(output_layout, wlr_output); | ||||
| 	else | ||||
| 		wlr_output_layout_add(output_layout, wlr_output, m->m.x, m->m.y); | ||||
| 	strncpy(m->ltsymbol, m->lt[m->sellt]->symbol, LENGTH(m->ltsymbol)); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| @ -1206,7 +1207,7 @@ void | ||||
| focusclient(Client *c, int lift) | ||||
| { | ||||
| 	struct wlr_surface *old = seat->keyboard_state.focused_surface; | ||||
| 	int i; | ||||
| 	int i, unused_lx, unused_ly; | ||||
| 
 | ||||
| 	if (locked) | ||||
| 		return; | ||||
| @ -1241,7 +1242,7 @@ focusclient(Client *c, int lift) | ||||
| 		Client *w = NULL; | ||||
| 		LayerSurface *l = NULL; | ||||
| 		int type = toplevel_from_wlr_surface(old, &w, &l); | ||||
| 		if (type == LayerShell && l->scene->node.enabled | ||||
| 		if (type == LayerShell && wlr_scene_node_coords(&l->scene->node, &unused_lx, &unused_ly) | ||||
| 				&& l->layer_surface->current.layer >= ZWLR_LAYER_SHELL_V1_LAYER_TOP) { | ||||
| 			return; | ||||
| 		} else if (w && w == exclusive_focus && client_wants_focus(w)) { | ||||
| @ -1598,12 +1599,16 @@ void | ||||
| monocle(Monitor *m) | ||||
| { | ||||
| 	Client *c; | ||||
| 	int n = 0; | ||||
| 
 | ||||
| 	wl_list_for_each(c, &clients, link) { | ||||
| 		if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen) | ||||
| 			continue; | ||||
| 		resize(c, m->w, 0); | ||||
| 		n++; | ||||
| 	} | ||||
| 	if (n) | ||||
| 		snprintf(m->ltsymbol, LENGTH(m->ltsymbol), "[%d]", n); | ||||
| 	if ((c = focustop(m))) | ||||
| 		wlr_scene_node_raise_to_top(&c->scene->node); | ||||
| } | ||||
| @ -1826,7 +1831,7 @@ printstatus(void) | ||||
| { | ||||
| 	Monitor *m = NULL; | ||||
| 	Client *c; | ||||
| 	unsigned int occ, urg, sel; | ||||
| 	uint32_t occ, urg, sel; | ||||
| 	const char *appid, *title; | ||||
| 
 | ||||
| 	wl_list_for_each(m, &mons, link) { | ||||
| @ -1857,7 +1862,7 @@ printstatus(void) | ||||
| 		printf("%s selmon %u\n", m->wlr_output->name, m == selmon); | ||||
| 		printf("%s tags %u %u %u %u\n", m->wlr_output->name, occ, m->tagset[m->seltags], | ||||
| 				sel, urg); | ||||
| 		printf("%s layout %s\n", m->wlr_output->name, m->lt[m->sellt]->symbol); | ||||
| 		printf("%s layout %s\n", m->wlr_output->name, m->ltsymbol); | ||||
| 	} | ||||
| 	fflush(stdout); | ||||
| } | ||||
| @ -2058,7 +2063,7 @@ setlayout(const Arg *arg) | ||||
| 		selmon->sellt ^= 1; | ||||
| 	if (arg && arg->v) | ||||
| 		selmon->lt[selmon->sellt] = (Layout *)arg->v; | ||||
| 	/* TODO change layout symbol? */ | ||||
| 	strncpy(selmon->ltsymbol, selmon->lt[selmon->sellt]->symbol, LENGTH(selmon->ltsymbol)); | ||||
| 	arrange(selmon); | ||||
| 	printstatus(); | ||||
| } | ||||
| @ -2079,7 +2084,7 @@ setmfact(const Arg *arg) | ||||
| } | ||||
| 
 | ||||
| void | ||||
| setmon(Client *c, Monitor *m, unsigned int newtags) | ||||
| setmon(Client *c, Monitor *m, uint32_t newtags) | ||||
| { | ||||
| 	Monitor *oldmon = c->mon; | ||||
| 
 | ||||
| @ -2431,7 +2436,7 @@ togglefullscreen(const Arg *arg) | ||||
| void | ||||
| toggletag(const Arg *arg) | ||||
| { | ||||
| 	unsigned int newtags; | ||||
| 	uint32_t newtags; | ||||
| 	Client *sel = focustop(selmon); | ||||
| 	if (!sel) | ||||
| 		return; | ||||
| @ -2447,7 +2452,7 @@ toggletag(const Arg *arg) | ||||
| void | ||||
| toggleview(const Arg *arg) | ||||
| { | ||||
| 	unsigned int newtagset = selmon ? selmon->tagset[selmon->seltags] ^ (arg->ui & TAGMASK) : 0; | ||||
| 	uint32_t newtagset = selmon ? selmon->tagset[selmon->seltags] ^ (arg->ui & TAGMASK) : 0; | ||||
| 
 | ||||
| 	if (newtagset) { | ||||
| 		selmon->tagset[selmon->seltags] = newtagset; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Leonardo Hernández Hernández
						Leonardo Hernández Hernández