aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLeonardo Hernández Hernández <leohdz172@proton.me>2023-10-05 22:20:08 -0600
committerLeonardo Hernández Hernández <leohdz172@proton.me>2023-10-09 11:05:41 -0600
commita18c52830010675cc794984c86db6c39776f914a (patch)
tree8126cb13a7ea24007d9737e86ba2441c0f0cccc4
parent72a7d78a1a7926a207539eb50f44b2e1eb089d49 (diff)
simplify setting the border color of clients
-rw-r--r--client.h8
-rw-r--r--dwl.c18
2 files changed, 13 insertions, 13 deletions
diff --git a/client.h b/client.h
index 5a45edc..cf1ed85 100644
--- a/client.h
+++ b/client.h
@@ -324,6 +324,14 @@ client_send_close(Client *c)
}
static inline void
+client_set_border_color(Client *c, const float color[static 4])
+{
+ int i;
+ for (i = 0; i < 4; i++)
+ wlr_scene_rect_set_color(c->border[i], color);
+}
+
+static inline void
client_set_fullscreen(Client *c, int fullscreen)
{
#ifdef XWAYLAND
diff --git a/dwl.c b/dwl.c
index 87f0636..33b370c 100644
--- a/dwl.c
+++ b/dwl.c
@@ -1199,7 +1199,7 @@ void
focusclient(Client *c, int lift)
{
struct wlr_surface *old = seat->keyboard_state.focused_surface;
- int i, unused_lx, unused_ly, old_client_type;
+ int unused_lx, unused_ly, old_client_type;
Client *old_c = NULL;
LayerSurface *old_l = NULL;
@@ -1230,8 +1230,7 @@ focusclient(Client *c, int lift)
/* Don't change border color if there is an exclusive focus or we are
* handling a drag operation */
if (!exclusive_focus && !seat->drag)
- for (i = 0; i < 4; i++)
- wlr_scene_rect_set_color(c->border[i], focuscolor);
+ client_set_border_color(c, focuscolor);
}
/* Deactivate old client if focus is changing */
@@ -1248,8 +1247,7 @@ focusclient(Client *c, int lift)
/* Don't deactivate old client if the new one wants focus, as this causes issues with winecfg
* and probably other clients */
} 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(old_c->border[i], bordercolor);
+ client_set_border_color(old_c, bordercolor);
client_activate_surface(old, 0);
}
@@ -2589,14 +2587,11 @@ urgent(struct wl_listener *listener, void *data)
{
struct wlr_xdg_activation_v1_request_activate_event *event = data;
Client *c = NULL;
- int i;
toplevel_from_wlr_surface(event->surface, &c, NULL);
if (!c || c == focustop(selmon))
return;
- for (i = 0; i < 4; i++)
- wlr_scene_rect_set_color(c->border[i], urgentcolor);
-
+ client_set_border_color(c, urgentcolor);
c->isurgent = 1;
printstatus();
}
@@ -2756,13 +2751,10 @@ void
sethints(struct wl_listener *listener, void *data)
{
Client *c = wl_container_of(listener, c, set_hints);
- int i;
if (c == focustop(selmon))
return;
- for (i = 0; i < 4; i++)
- wlr_scene_rect_set_color(c->border[i], urgentcolor);
-
+ client_set_border_color(c, urgentcolor);
c->isurgent = xcb_icccm_wm_hints_get_urgency(c->surface.xwayland->hints);
printstatus();
}