~ruther/dwl

a8ccbe63f3ca06d2fac880414e68c7b3ca0ae88f — Leonardo Hernández Hernández 1 year, 10 months ago 2d1a40c + 9b9b79b
Merge branch 'main' into wlroots-next
2 files changed, 25 insertions(+), 18 deletions(-)

M .github/ISSUE_TEMPLATE/bug_report.md
M dwl.c
M .github/ISSUE_TEMPLATE/bug_report.md => .github/ISSUE_TEMPLATE/bug_report.md +0 -5
@@ 14,9 14,4 @@ wlroots version:
<!--
Only report bugs that can be reproduced on the main line
Report patch issues to their respective authors
If the patch author doesn't respond within a reasonable time, email me:

Leonardo Hernández Hernández <leohdz172@protonmail.com>

but note that I'm NOT making any promises
-->

M dwl.c => dwl.c +25 -13
@@ 843,8 843,10 @@ createlayersurface(struct wl_listener *listener, void *data)
	if (!wlr_layer_surface->output)
		wlr_layer_surface->output = selmon ? selmon->wlr_output : NULL;

	if (!wlr_layer_surface->output)
	if (!wlr_layer_surface->output) {
		wlr_layer_surface_v1_destroy(wlr_layer_surface);
		return;
	}

	layersurface = ecalloc(1, sizeof(LayerSurface));
	layersurface->type = LayerShell;


@@ 1207,7 1209,9 @@ void
focusclient(Client *c, int lift)
{
	struct wlr_surface *old = seat->keyboard_state.focused_surface;
	int i, unused_lx, unused_ly;
	int i, unused_lx, unused_ly, old_client_type;
	Client *old_c = NULL;
	LayerSurface *old_l = NULL;

	if (locked)
		return;


@@ 1219,6 1223,12 @@ focusclient(Client *c, int lift)
	if (c && client_surface(c) == old)
		return;

	if ((old_client_type = toplevel_from_wlr_surface(old, &old_c, &old_l)) == XDGShell) {
		struct wlr_xdg_popup *popup, *tmp;
		wl_list_for_each_safe(popup, tmp, &old_c->surface.xdg->popups, link)
			wlr_xdg_popup_destroy(popup);
	}

	/* Put the new client atop the focus stack and select its monitor */
	if (c && !client_is_unmanaged(c)) {
		wl_list_remove(&c->flink);


@@ 1239,19 1249,17 @@ focusclient(Client *c, int lift)
		/* If an overlay is focused, don't focus or activate the client,
		 * but only update its position in fstack to render its border with focuscolor
		 * and focus it after the overlay is closed. */
		Client *w = NULL;
		LayerSurface *l = NULL;
		int type = toplevel_from_wlr_surface(old, &w, &l);
		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) {
		if (old_client_type == LayerShell && wlr_scene_node_coords(
					&old_l->scene->node, &unused_lx, &unused_ly)
				&& old_l->layer_surface->current.layer >= ZWLR_LAYER_SHELL_V1_LAYER_TOP) {
			return;
		} else if (w && w == exclusive_focus && client_wants_focus(w)) {
		} else if (old_c && old_c == exclusive_focus && client_wants_focus(old_c)) {
			return;
		/* Don't deactivate old client if the new one wants focus, as this causes issues with winecfg
		 * and probably other clients */
		} else if (w && !client_is_unmanaged(w) && (!c || !client_wants_focus(c))) {
		} else if (old_c && !client_is_unmanaged(old_c) && (!c || !client_wants_focus(c))) {
			for (i = 0; i < 4; i++)
				wlr_scene_rect_set_color(w->border[i], bordercolor);
				wlr_scene_rect_set_color(old_c->border[i], bordercolor);

			client_activate_surface(old, 0);
		}


@@ 1893,8 1901,8 @@ rendermon(struct wl_listener *listener, void *data)
	wl_list_for_each(c, &clients, link)
		if (c->resize && !c->isfloating && client_is_rendered_on_mon(c, m) && !client_is_stopped(c))
			goto skip;
	if (!wlr_scene_output_commit(m->scene_output))
		return;
	wlr_scene_output_commit(m->scene_output);

skip:
	/* Let clients know a frame has been rendered */
	clock_gettime(CLOCK_MONOTONIC, &now);


@@ 2279,6 2287,7 @@ setup(void)
	 * images are available at all scale factors on the screen (necessary for
	 * HiDPI support). Scaled cursors will be loaded with each output. */
	cursor_mgr = wlr_xcursor_manager_create(NULL, 24);
	setenv("XCURSOR_SIZE", "24", 1);

	/*
	 * wlr_cursor *only* displays an image on screen. It does not move around


@@ 2590,9 2599,12 @@ updatemons(struct wl_listener *listener, void *data)
		wl_list_for_each(c, &clients, link)
			if (!c->mon && client_is_mapped(c))
				setmon(c, selmon, c->tags);
		if (selmon->lock_surface)
		focusclient(focustop(selmon), 1);
		if (selmon->lock_surface) {
			client_notify_enter(selmon->lock_surface->surface,
					wlr_seat_get_keyboard(seat));
			client_activate_surface(selmon->lock_surface->surface, 1);
		}
	}

	wlr_output_manager_v1_set_configuration(output_mgr, config);

Do not follow this link