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 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 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 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 bordercolor[]           = {0.5, 0.5, 0.5, 1.0}; | ||||||
| static const float focuscolor[]            = {1.0, 0.0, 0.0, 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 */ | /* 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}; | static const float fullscreen_bg[]         = {0.1, 0.1, 0.1, 1.0}; | ||||||
| 
 | 
 | ||||||
| /* tagging */ | /* tagging - tagcount must be no greater than 31 */ | ||||||
| static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" }; | static const int tagcount = 9; | ||||||
| 
 | 
 | ||||||
| static const Rule rules[] = { | static const Rule rules[] = { | ||||||
| 	/* app_id     title       tags mask     isfloating   monitor */ | 	/* app_id     title       tags mask     isfloating   monitor */ | ||||||
| @ -31,7 +30,7 @@ static const Layout layouts[] = { | |||||||
| static const MonitorRule monrules[] = { | static const MonitorRule monrules[] = { | ||||||
| 	/* name       mfact nmaster scale layout       rotate/reflect                x    y */ | 	/* name       mfact nmaster scale layout       rotate/reflect                x    y */ | ||||||
| 	/* example of a HiDPI laptop monitor:
 | 	/* 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 */ | 	/* defaults */ | ||||||
| 	{ NULL,       0.55, 1,      1,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL,   -1,  -1 }, | 	{ 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 VISIBLEON(C, M)         ((M) && (C)->mon == (M) && ((C)->tags & (M)->tagset[(M)->seltags])) | ||||||
| #define LENGTH(X)               (sizeof X / sizeof X[0]) | #define LENGTH(X)               (sizeof X / sizeof X[0]) | ||||||
| #define END(A)                  ((A) + LENGTH(A)) | #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 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) | #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 { | typedef union { | ||||||
| 	int i; | 	int i; | ||||||
| 	unsigned int ui; | 	uint32_t ui; | ||||||
| 	float f; | 	float f; | ||||||
| 	const void *v; | 	const void *v; | ||||||
| } Arg; | } Arg; | ||||||
| @ -126,7 +126,7 @@ typedef struct { | |||||||
| 	struct wl_listener set_hints; | 	struct wl_listener set_hints; | ||||||
| #endif | #endif | ||||||
| 	unsigned int bw; | 	unsigned int bw; | ||||||
| 	unsigned int tags; | 	uint32_t tags; | ||||||
| 	int isfloating, isurgent, isfullscreen; | 	int isfloating, isurgent, isfullscreen; | ||||||
| 	uint32_t resize; /* configure serial of a pending resize */ | 	uint32_t resize; /* configure serial of a pending resize */ | ||||||
| } Client; | } Client; | ||||||
| @ -191,9 +191,10 @@ struct Monitor { | |||||||
| 	const Layout *lt[2]; | 	const Layout *lt[2]; | ||||||
| 	unsigned int seltags; | 	unsigned int seltags; | ||||||
| 	unsigned int sellt; | 	unsigned int sellt; | ||||||
| 	unsigned int tagset[2]; | 	uint32_t tagset[2]; | ||||||
| 	double mfact; | 	double mfact; | ||||||
| 	int nmaster; | 	int nmaster; | ||||||
|  | 	char ltsymbol[16]; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| typedef struct { | typedef struct { | ||||||
| @ -209,7 +210,7 @@ typedef struct { | |||||||
| typedef struct { | typedef struct { | ||||||
| 	const char *id; | 	const char *id; | ||||||
| 	const char *title; | 	const char *title; | ||||||
| 	unsigned int tags; | 	uint32_t tags; | ||||||
| 	int isfloating; | 	int isfloating; | ||||||
| 	int monitor; | 	int monitor; | ||||||
| } Rule; | } Rule; | ||||||
| @ -297,7 +298,7 @@ static void setfloating(Client *c, int floating); | |||||||
| static void setfullscreen(Client *c, int fullscreen); | static void setfullscreen(Client *c, int fullscreen); | ||||||
| static void setlayout(const Arg *arg); | static void setlayout(const Arg *arg); | ||||||
| static void setmfact(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 setpsel(struct wl_listener *listener, void *data); | ||||||
| static void setsel(struct wl_listener *listener, void *data); | static void setsel(struct wl_listener *listener, void *data); | ||||||
| static void setup(void); | static void setup(void); | ||||||
| @ -416,9 +417,6 @@ static Atom netatom[NetLast]; | |||||||
| /* attempt to encapsulate suck into one file */ | /* attempt to encapsulate suck into one file */ | ||||||
| #include "client.h" | #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 */ | /* function implementations */ | ||||||
| void | void | ||||||
| applybounds(Client *c, struct wlr_box *bbox) | applybounds(Client *c, struct wlr_box *bbox) | ||||||
| @ -429,8 +427,8 @@ applybounds(Client *c, struct wlr_box *bbox) | |||||||
| 		/* try to set size hints */ | 		/* try to set size hints */ | ||||||
| 		c->geom.width = MAX(min.width + (2 * (int)c->bw), c->geom.width); | 		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); | 		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
 | 		/* Some clients set their max size to INT_MAX, which does not violate the
 | ||||||
| 		 * the protocol but its innecesary, they can set them max size to zero. */ | 		 * 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 */ | 		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); | 			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 */ | 		if (max.height > 0 && !(2 * c->bw > INT_MAX - max.height)) /* Checks for overflow */ | ||||||
| @ -452,7 +450,7 @@ applyrules(Client *c) | |||||||
| { | { | ||||||
| 	/* rule matching */ | 	/* rule matching */ | ||||||
| 	const char *appid, *title; | 	const char *appid, *title; | ||||||
| 	unsigned int i, newtags = 0; | 	uint32_t i, newtags = 0; | ||||||
| 	const Rule *r; | 	const Rule *r; | ||||||
| 	Monitor *mon = selmon, *m; | 	Monitor *mon = selmon, *m; | ||||||
| 
 | 
 | ||||||
| @ -488,7 +486,9 @@ arrange(Monitor *m) | |||||||
| 	wlr_scene_node_set_enabled(&m->fullscreen_bg->node, | 	wlr_scene_node_set_enabled(&m->fullscreen_bg->node, | ||||||
| 			(c = focustop(m)) && c->isfullscreen); | 			(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); | 		m->lt[m->sellt]->arrange(m); | ||||||
| 	motionnotify(0); | 	motionnotify(0); | ||||||
| 	checkidleinhibitor(NULL); | 	checkidleinhibitor(NULL); | ||||||
| @ -638,13 +638,13 @@ chvt(const Arg *arg) | |||||||
| void | void | ||||||
| checkidleinhibitor(struct wlr_surface *exclude) | checkidleinhibitor(struct wlr_surface *exclude) | ||||||
| { | { | ||||||
| 	int inhibited = 0; | 	int inhibited = 0, unused_lx, unused_ly; | ||||||
| 	struct wlr_idle_inhibitor_v1 *inhibitor; | 	struct wlr_idle_inhibitor_v1 *inhibitor; | ||||||
| 	wl_list_for_each(inhibitor, &idle_inhibit_mgr->inhibitors, link) { | 	wl_list_for_each(inhibitor, &idle_inhibit_mgr->inhibitors, link) { | ||||||
| 		struct wlr_surface *surface = wlr_surface_get_root_surface(inhibitor->surface); | 		struct wlr_surface *surface = wlr_surface_get_root_surface(inhibitor->surface); | ||||||
| 		struct wlr_scene_tree *tree = surface->data; | 		struct wlr_scene_tree *tree = surface->data; | ||||||
| 		if (exclude != surface && (bypass_surface_visibility || (!tree | 		if (exclude != surface && (bypass_surface_visibility || (!tree | ||||||
| 				|| tree->node.enabled))) { | 				|| wlr_scene_node_coords(&tree->node, &unused_lx, &unused_ly)))) { | ||||||
| 			inhibited = 1; | 			inhibited = 1; | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| @ -978,6 +978,7 @@ createmon(struct wl_listener *listener, void *data) | |||||||
| 		wlr_output_layout_add_auto(output_layout, wlr_output); | 		wlr_output_layout_add_auto(output_layout, wlr_output); | ||||||
| 	else | 	else | ||||||
| 		wlr_output_layout_add(output_layout, wlr_output, m->m.x, m->m.y); | 		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 | void | ||||||
| @ -1206,7 +1207,7 @@ void | |||||||
| focusclient(Client *c, int lift) | focusclient(Client *c, int lift) | ||||||
| { | { | ||||||
| 	struct wlr_surface *old = seat->keyboard_state.focused_surface; | 	struct wlr_surface *old = seat->keyboard_state.focused_surface; | ||||||
| 	int i; | 	int i, unused_lx, unused_ly; | ||||||
| 
 | 
 | ||||||
| 	if (locked) | 	if (locked) | ||||||
| 		return; | 		return; | ||||||
| @ -1241,7 +1242,7 @@ focusclient(Client *c, int lift) | |||||||
| 		Client *w = NULL; | 		Client *w = NULL; | ||||||
| 		LayerSurface *l = NULL; | 		LayerSurface *l = NULL; | ||||||
| 		int type = toplevel_from_wlr_surface(old, &w, &l); | 		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) { | 				&& l->layer_surface->current.layer >= ZWLR_LAYER_SHELL_V1_LAYER_TOP) { | ||||||
| 			return; | 			return; | ||||||
| 		} else if (w && w == exclusive_focus && client_wants_focus(w)) { | 		} else if (w && w == exclusive_focus && client_wants_focus(w)) { | ||||||
| @ -1598,12 +1599,16 @@ void | |||||||
| monocle(Monitor *m) | monocle(Monitor *m) | ||||||
| { | { | ||||||
| 	Client *c; | 	Client *c; | ||||||
|  | 	int n = 0; | ||||||
| 
 | 
 | ||||||
| 	wl_list_for_each(c, &clients, link) { | 	wl_list_for_each(c, &clients, link) { | ||||||
| 		if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen) | 		if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen) | ||||||
| 			continue; | 			continue; | ||||||
| 		resize(c, m->w, 0); | 		resize(c, m->w, 0); | ||||||
|  | 		n++; | ||||||
| 	} | 	} | ||||||
|  | 	if (n) | ||||||
|  | 		snprintf(m->ltsymbol, LENGTH(m->ltsymbol), "[%d]", n); | ||||||
| 	if ((c = focustop(m))) | 	if ((c = focustop(m))) | ||||||
| 		wlr_scene_node_raise_to_top(&c->scene->node); | 		wlr_scene_node_raise_to_top(&c->scene->node); | ||||||
| } | } | ||||||
| @ -1826,7 +1831,7 @@ printstatus(void) | |||||||
| { | { | ||||||
| 	Monitor *m = NULL; | 	Monitor *m = NULL; | ||||||
| 	Client *c; | 	Client *c; | ||||||
| 	unsigned int occ, urg, sel; | 	uint32_t occ, urg, sel; | ||||||
| 	const char *appid, *title; | 	const char *appid, *title; | ||||||
| 
 | 
 | ||||||
| 	wl_list_for_each(m, &mons, link) { | 	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 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], | 		printf("%s tags %u %u %u %u\n", m->wlr_output->name, occ, m->tagset[m->seltags], | ||||||
| 				sel, urg); | 				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); | 	fflush(stdout); | ||||||
| } | } | ||||||
| @ -2058,7 +2063,7 @@ setlayout(const Arg *arg) | |||||||
| 		selmon->sellt ^= 1; | 		selmon->sellt ^= 1; | ||||||
| 	if (arg && arg->v) | 	if (arg && arg->v) | ||||||
| 		selmon->lt[selmon->sellt] = (Layout *)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); | 	arrange(selmon); | ||||||
| 	printstatus(); | 	printstatus(); | ||||||
| } | } | ||||||
| @ -2079,7 +2084,7 @@ setmfact(const Arg *arg) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| setmon(Client *c, Monitor *m, unsigned int newtags) | setmon(Client *c, Monitor *m, uint32_t newtags) | ||||||
| { | { | ||||||
| 	Monitor *oldmon = c->mon; | 	Monitor *oldmon = c->mon; | ||||||
| 
 | 
 | ||||||
| @ -2431,7 +2436,7 @@ togglefullscreen(const Arg *arg) | |||||||
| void | void | ||||||
| toggletag(const Arg *arg) | toggletag(const Arg *arg) | ||||||
| { | { | ||||||
| 	unsigned int newtags; | 	uint32_t newtags; | ||||||
| 	Client *sel = focustop(selmon); | 	Client *sel = focustop(selmon); | ||||||
| 	if (!sel) | 	if (!sel) | ||||||
| 		return; | 		return; | ||||||
| @ -2447,7 +2452,7 @@ toggletag(const Arg *arg) | |||||||
| void | void | ||||||
| toggleview(const Arg *arg) | 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) { | 	if (newtagset) { | ||||||
| 		selmon->tagset[selmon->seltags] = newtagset; | 		selmon->tagset[selmon->seltags] = newtagset; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user