C99 doesn't support anonymous unions
I'm cool with ->surface.xdg instead of ->xdg_surface though.
This commit is contained in:
		
							parent
							
								
									62339e7ab0
								
							
						
					
					
						commit
						17e525cc6c
					
				
							
								
								
									
										88
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										88
									
								
								dwl.c
									
									
									
									
									
								
							| @ -43,7 +43,7 @@ | |||||||
| #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                 ((1 << LENGTH(tags)) - 1) | ||||||
| #define WLR_SURFACE(C)          ((C)->type != XDGShell ? (C)->xwayland_surface->surface : (C)->xdg_surface->surface) | #define WLR_SURFACE(C)          ((C)->type != XDGShell ? (C)->surface.xwayland->surface : (C)->surface.xdg->surface) | ||||||
| 
 | 
 | ||||||
| /* enums */ | /* enums */ | ||||||
| enum { CurNormal, CurMove, CurResize }; /* cursor */ | enum { CurNormal, CurMove, CurResize }; /* cursor */ | ||||||
| @ -71,9 +71,9 @@ typedef struct { | |||||||
| 	struct wl_list flink; | 	struct wl_list flink; | ||||||
| 	struct wl_list slink; | 	struct wl_list slink; | ||||||
| 	union { | 	union { | ||||||
| 		struct wlr_xdg_surface *xdg_surface; | 		struct wlr_xdg_surface *xdg; | ||||||
| 		struct wlr_xwayland_surface *xwayland_surface; | 		struct wlr_xwayland_surface *xwayland; | ||||||
| 	}; | 	} surface; | ||||||
| 	struct wl_listener activate; | 	struct wl_listener activate; | ||||||
| 	struct wl_listener commit; | 	struct wl_listener commit; | ||||||
| 	struct wl_listener map; | 	struct wl_listener map; | ||||||
| @ -285,7 +285,7 @@ activatex11(struct wl_listener *listener, void *data) | |||||||
| 
 | 
 | ||||||
|        /* Only "managed" windows can be activated */ |        /* Only "managed" windows can be activated */ | ||||||
|        if (c->type == X11Managed) |        if (c->type == X11Managed) | ||||||
|                wlr_xwayland_surface_activate(c->xwayland_surface, 1); |                wlr_xwayland_surface_activate(c->surface.xwayland, 1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| @ -315,10 +315,10 @@ applyrules(Client *c) | |||||||
| 
 | 
 | ||||||
| 	/* rule matching */ | 	/* rule matching */ | ||||||
| 	c->isfloating = 0; | 	c->isfloating = 0; | ||||||
| 	appid = c->type != XDGShell ? c->xwayland_surface->class : | 	appid = c->type != XDGShell ? c->surface.xwayland->class : | ||||||
| 		c->xdg_surface->toplevel->app_id; | 		c->surface.xdg->toplevel->app_id; | ||||||
| 	title = c->type != XDGShell ? c->xwayland_surface->title : | 	title = c->type != XDGShell ? c->surface.xwayland->title : | ||||||
| 		c->xdg_surface->toplevel->title; | 		c->surface.xdg->toplevel->title; | ||||||
| 	if (!appid) | 	if (!appid) | ||||||
| 		appid = broken; | 		appid = broken; | ||||||
| 	if (!title) | 	if (!title) | ||||||
| @ -377,11 +377,11 @@ buttonpress(struct wl_listener *listener, void *data) | |||||||
| 		/* Change focus if the button was _pressed_ over a client */ | 		/* Change focus if the button was _pressed_ over a client */ | ||||||
| 		if ((c = xytoclient(cursor->x, cursor->y))) { | 		if ((c = xytoclient(cursor->x, cursor->y))) { | ||||||
| 			if (c->type != XDGShell) | 			if (c->type != XDGShell) | ||||||
| 				surface = wlr_surface_surface_at(c->xwayland_surface->surface, | 				surface = wlr_surface_surface_at(c->surface.xwayland->surface, | ||||||
| 						cursor->x - c->geom.x - c->bw, | 						cursor->x - c->geom.x - c->bw, | ||||||
| 						cursor->y - c->geom.y - c->bw, NULL, NULL); | 						cursor->y - c->geom.y - c->bw, NULL, NULL); | ||||||
| 			else | 			else | ||||||
| 				surface = wlr_xdg_surface_surface_at(c->xdg_surface, | 				surface = wlr_xdg_surface_surface_at(c->surface.xdg, | ||||||
| 						cursor->x - c->geom.x - c->bw, | 						cursor->x - c->geom.x - c->bw, | ||||||
| 						cursor->y - c->geom.y - c->bw, NULL, NULL); | 						cursor->y - c->geom.y - c->bw, NULL, NULL); | ||||||
| 			focusclient(c, surface, 1); | 			focusclient(c, surface, 1); | ||||||
| @ -452,7 +452,7 @@ commitnotify(struct wl_listener *listener, void *data) | |||||||
| 	Client *c = wl_container_of(listener, c, commit); | 	Client *c = wl_container_of(listener, c, commit); | ||||||
| 
 | 
 | ||||||
| 	/* mark a pending resize as completed */ | 	/* mark a pending resize as completed */ | ||||||
| 	if (c->resize && c->resize <= c->xdg_surface->configure_serial) | 	if (c->resize && c->resize <= c->surface.xdg->configure_serial) | ||||||
| 		c->resize = 0; | 		c->resize = 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -558,12 +558,12 @@ createnotify(struct wl_listener *listener, void *data) | |||||||
| 
 | 
 | ||||||
| 	/* Allocate a Client for this surface */ | 	/* Allocate a Client for this surface */ | ||||||
| 	c = xdg_surface->data = calloc(1, sizeof(*c)); | 	c = xdg_surface->data = calloc(1, sizeof(*c)); | ||||||
| 	c->xdg_surface = xdg_surface; | 	c->surface.xdg = xdg_surface; | ||||||
| 	c->type = XDGShell; | 	c->type = XDGShell; | ||||||
| 	c->bw = borderpx; | 	c->bw = borderpx; | ||||||
| 
 | 
 | ||||||
| 	/* Tell the client not to try anything fancy */ | 	/* Tell the client not to try anything fancy */ | ||||||
| 	wlr_xdg_toplevel_set_tiled(c->xdg_surface, WLR_EDGE_TOP | | 	wlr_xdg_toplevel_set_tiled(c->surface.xdg, WLR_EDGE_TOP | | ||||||
| 			WLR_EDGE_BOTTOM | WLR_EDGE_LEFT | WLR_EDGE_RIGHT); | 			WLR_EDGE_BOTTOM | WLR_EDGE_LEFT | WLR_EDGE_RIGHT); | ||||||
| 
 | 
 | ||||||
| 	/* Listen to the various events it can emit */ | 	/* Listen to the various events it can emit */ | ||||||
| @ -585,7 +585,7 @@ createnotifyx11(struct wl_listener *listener, void *data) | |||||||
| 
 | 
 | ||||||
| 	/* Allocate a Client for this surface */ | 	/* Allocate a Client for this surface */ | ||||||
| 	c = xwayland_surface->data = calloc(1, sizeof(*c)); | 	c = xwayland_surface->data = calloc(1, sizeof(*c)); | ||||||
| 	c->xwayland_surface = xwayland_surface; | 	c->surface.xwayland = xwayland_surface; | ||||||
| 	c->type = xwayland_surface->override_redirect ? X11Unmanaged : X11Managed; | 	c->type = xwayland_surface->override_redirect ? X11Unmanaged : X11Managed; | ||||||
| 	c->bw = borderpx; | 	c->bw = borderpx; | ||||||
| 
 | 
 | ||||||
| @ -691,9 +691,9 @@ focusclient(Client *c, struct wlr_surface *surface, int lift) | |||||||
| 	/* Deactivate old client if focus is changing */ | 	/* Deactivate old client if focus is changing */ | ||||||
| 	if (c != old && old) { | 	if (c != old && old) { | ||||||
| 		if (old->type != XDGShell) | 		if (old->type != XDGShell) | ||||||
| 			wlr_xwayland_surface_activate(old->xwayland_surface, 0); | 			wlr_xwayland_surface_activate(old->surface.xwayland, 0); | ||||||
| 		else | 		else | ||||||
| 			wlr_xdg_toplevel_set_activated(old->xdg_surface, 0); | 			wlr_xdg_toplevel_set_activated(old->surface.xdg, 0); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/* Update wlroots' keyboard focus */ | 	/* Update wlroots' keyboard focus */ | ||||||
| @ -719,9 +719,9 @@ focusclient(Client *c, struct wlr_surface *surface, int lift) | |||||||
| 
 | 
 | ||||||
| 	/* Activate the new client */ | 	/* Activate the new client */ | ||||||
| 	if (c->type != XDGShell) | 	if (c->type != XDGShell) | ||||||
| 		wlr_xwayland_surface_activate(c->xwayland_surface, 1); | 		wlr_xwayland_surface_activate(c->surface.xwayland, 1); | ||||||
| 	else | 	else | ||||||
| 		wlr_xdg_toplevel_set_activated(c->xdg_surface, 1); | 		wlr_xdg_toplevel_set_activated(c->surface.xdg, 1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| @ -897,9 +897,9 @@ killclient(const Arg *arg) | |||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
| 	if (sel->type != XDGShell) | 	if (sel->type != XDGShell) | ||||||
| 		wlr_xwayland_surface_close(sel->xwayland_surface); | 		wlr_xwayland_surface_close(sel->surface.xwayland); | ||||||
| 	else | 	else | ||||||
| 		wlr_xdg_toplevel_send_close(sel->xdg_surface); | 		wlr_xdg_toplevel_send_close(sel->surface.xdg); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Client * | Client * | ||||||
| @ -930,12 +930,12 @@ maprequest(struct wl_listener *listener, void *data) | |||||||
| 	wl_list_insert(&stack, &c->slink); | 	wl_list_insert(&stack, &c->slink); | ||||||
| 
 | 
 | ||||||
| 	if (c->type != XDGShell) { | 	if (c->type != XDGShell) { | ||||||
| 		c->geom.x = c->xwayland_surface->x; | 		c->geom.x = c->surface.xwayland->x; | ||||||
| 		c->geom.y = c->xwayland_surface->y; | 		c->geom.y = c->surface.xwayland->y; | ||||||
| 		c->geom.width = c->xwayland_surface->width + 2 * c->bw; | 		c->geom.width = c->surface.xwayland->width + 2 * c->bw; | ||||||
| 		c->geom.height = c->xwayland_surface->height + 2 * c->bw; | 		c->geom.height = c->surface.xwayland->height + 2 * c->bw; | ||||||
| 	} else { | 	} else { | ||||||
| 		wlr_xdg_surface_get_geometry(c->xdg_surface, &c->geom); | 		wlr_xdg_surface_get_geometry(c->surface.xdg, &c->geom); | ||||||
| 		c->geom.width += 2 * c->bw; | 		c->geom.width += 2 * c->bw; | ||||||
| 		c->geom.height += 2 * c->bw; | 		c->geom.height += 2 * c->bw; | ||||||
| 	} | 	} | ||||||
| @ -985,11 +985,11 @@ motionnotify(uint32_t time) | |||||||
| 	/* Otherwise, find the client under the pointer and send the event along. */ | 	/* Otherwise, find the client under the pointer and send the event along. */ | ||||||
| 	if ((c = xytoclient(cursor->x, cursor->y))) { | 	if ((c = xytoclient(cursor->x, cursor->y))) { | ||||||
| 		if (c->type != XDGShell) | 		if (c->type != XDGShell) | ||||||
| 			surface = wlr_surface_surface_at(c->xwayland_surface->surface, | 			surface = wlr_surface_surface_at(c->surface.xwayland->surface, | ||||||
| 					cursor->x - c->geom.x - c->bw, | 					cursor->x - c->geom.x - c->bw, | ||||||
| 					cursor->y - c->geom.y - c->bw, &sx, &sy); | 					cursor->y - c->geom.y - c->bw, &sx, &sy); | ||||||
| 		else | 		else | ||||||
| 			surface = wlr_xdg_surface_surface_at(c->xdg_surface, | 			surface = wlr_xdg_surface_surface_at(c->surface.xdg, | ||||||
| 					cursor->x - c->geom.x - c->bw, | 					cursor->x - c->geom.x - c->bw, | ||||||
| 					cursor->y - c->geom.y - c->bw, &sx, &sy); | 					cursor->y - c->geom.y - c->bw, &sx, &sy); | ||||||
| 	} | 	} | ||||||
| @ -1183,9 +1183,9 @@ renderclients(Monitor *m, struct timespec *now) | |||||||
| 		rdata.x = c->geom.x + c->bw, | 		rdata.x = c->geom.x + c->bw, | ||||||
| 		rdata.y = c->geom.y + c->bw; | 		rdata.y = c->geom.y + c->bw; | ||||||
| 		if (c->type != XDGShell) | 		if (c->type != XDGShell) | ||||||
| 			wlr_surface_for_each_surface(c->xwayland_surface->surface, render, &rdata); | 			wlr_surface_for_each_surface(c->surface.xwayland->surface, render, &rdata); | ||||||
| 		else | 		else | ||||||
| 			wlr_xdg_surface_for_each_surface(c->xdg_surface, render, &rdata); | 			wlr_xdg_surface_for_each_surface(c->surface.xdg, render, &rdata); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1197,10 +1197,10 @@ renderindependents(struct wlr_output *output, struct timespec *now) | |||||||
| 	struct wlr_box geom; | 	struct wlr_box geom; | ||||||
| 
 | 
 | ||||||
| 	wl_list_for_each_reverse(c, &independents, link) { | 	wl_list_for_each_reverse(c, &independents, link) { | ||||||
| 		geom.x = c->xwayland_surface->x; | 		geom.x = c->surface.xwayland->x; | ||||||
| 		geom.y = c->xwayland_surface->y; | 		geom.y = c->surface.xwayland->y; | ||||||
| 		geom.width = c->xwayland_surface->width; | 		geom.width = c->surface.xwayland->width; | ||||||
| 		geom.height = c->xwayland_surface->height; | 		geom.height = c->surface.xwayland->height; | ||||||
| 
 | 
 | ||||||
| 		/* Only render visible clients which show on this output */ | 		/* Only render visible clients which show on this output */ | ||||||
| 		if (!wlr_output_layout_intersects(output_layout, output, &geom)) | 		if (!wlr_output_layout_intersects(output_layout, output, &geom)) | ||||||
| @ -1208,10 +1208,10 @@ renderindependents(struct wlr_output *output, struct timespec *now) | |||||||
| 
 | 
 | ||||||
| 		rdata.output = output, | 		rdata.output = output, | ||||||
| 		rdata.when = now, | 		rdata.when = now, | ||||||
| 		rdata.x = c->xwayland_surface->x; | 		rdata.x = c->surface.xwayland->x; | ||||||
| 		rdata.y = c->xwayland_surface->y; | 		rdata.y = c->surface.xwayland->y; | ||||||
| 
 | 
 | ||||||
| 		wlr_surface_for_each_surface(c->xwayland_surface->surface, render, &rdata); | 		wlr_surface_for_each_surface(c->surface.xwayland->surface, render, &rdata); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1280,11 +1280,11 @@ resize(Client *c, int x, int y, int w, int h, int interact) | |||||||
| 	applybounds(c, bbox); | 	applybounds(c, bbox); | ||||||
| 	/* wlroots makes this a no-op if size hasn't changed */ | 	/* wlroots makes this a no-op if size hasn't changed */ | ||||||
| 	if (c->type != XDGShell) | 	if (c->type != XDGShell) | ||||||
| 		wlr_xwayland_surface_configure(c->xwayland_surface, | 		wlr_xwayland_surface_configure(c->surface.xwayland, | ||||||
| 				c->geom.x, c->geom.y, | 				c->geom.x, c->geom.y, | ||||||
| 				c->geom.width - 2 * c->bw, c->geom.height - 2 * c->bw); | 				c->geom.width - 2 * c->bw, c->geom.height - 2 * c->bw); | ||||||
| 	else | 	else | ||||||
| 		c->resize = wlr_xdg_toplevel_set_size(c->xdg_surface, | 		c->resize = wlr_xdg_toplevel_set_size(c->surface.xdg, | ||||||
| 				c->geom.width - 2 * c->bw, c->geom.height - 2 * c->bw); | 				c->geom.width - 2 * c->bw, c->geom.height - 2 * c->bw); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1714,11 +1714,11 @@ updatewindowtype(Client *c) | |||||||
| 	size_t i; | 	size_t i; | ||||||
| 
 | 
 | ||||||
| 	if (c->type != XDGShell) | 	if (c->type != XDGShell) | ||||||
| 		for (i = 0; i < c->xwayland_surface->window_type_len; i++) | 		for (i = 0; i < c->surface.xwayland->window_type_len; i++) | ||||||
| 			if (c->xwayland_surface->window_type[i] == netatom[NetWMWindowTypeDialog] || | 			if (c->surface.xwayland->window_type[i] == netatom[NetWMWindowTypeDialog] || | ||||||
| 					c->xwayland_surface->window_type[i] == netatom[NetWMWindowTypeSplash] || | 					c->surface.xwayland->window_type[i] == netatom[NetWMWindowTypeSplash] || | ||||||
| 					c->xwayland_surface->window_type[i] == netatom[NetWMWindowTypeToolbar] || | 					c->surface.xwayland->window_type[i] == netatom[NetWMWindowTypeToolbar] || | ||||||
| 					c->xwayland_surface->window_type[i] == netatom[NetWMWindowTypeUtility]) | 					c->surface.xwayland->window_type[i] == netatom[NetWMWindowTypeUtility]) | ||||||
| 				c->isfloating = 1; | 				c->isfloating = 1; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user