aboutsummaryrefslogtreecommitdiff
path: root/dwl.c
diff options
context:
space:
mode:
authorDevin J. Pohly <djpohly@gmail.com>2020-04-26 13:18:20 -0500
committerDevin J. Pohly <djpohly@gmail.com>2020-04-26 13:18:20 -0500
commit48a8adb70a940842da80b324db6eed60b6f32b35 (patch)
tree223ce16783e47faa0a6b71c23d3740d1ac324d8d /dwl.c
parent5dd8a5f22fb00b5f7f5255f1ab7f03396206e936 (diff)
track window width/height
Diffstat (limited to 'dwl.c')
-rw-r--r--dwl.c32
1 files changed, 18 insertions, 14 deletions
diff --git a/dwl.c b/dwl.c
index 13a7f4b..d6608f8 100644
--- a/dwl.c
+++ b/dwl.c
@@ -66,7 +66,7 @@ typedef struct {
struct wl_listener request_move;
struct wl_listener request_resize;
Monitor *mon;
- int x, y; /* layout-relative, includes border */
+ int x, y, w, h; /* layout-relative, includes border */
int bw;
unsigned int tags;
int isfloating;
@@ -376,6 +376,10 @@ createnotify(struct wl_listener *listener, void *data)
Client *c = calloc(1, sizeof(*c));
c->xdg_surface = xdg_surface;
c->bw = borderpx;
+ struct wlr_box geom;
+ wlr_xdg_surface_get_geometry(c->xdg_surface, &geom);
+ c->w = geom.width + 2 * c->bw;
+ c->h = geom.height + 2 * c->bw;
/* Tell the client not to try anything fancy */
wlr_xdg_toplevel_set_tiled(c->xdg_surface, true);
@@ -660,8 +664,9 @@ motionnotify(uint32_t time)
if (cursor_mode == CurMove) {
/* Move the grabbed client to the new position. */
/* XXX assumes the surface is at (0,0) within grabc */
- grabc->x = cursor->x - grabsx - grabc->bw;
- grabc->y = cursor->y - grabsy - grabc->bw;
+ resize(grabc, cursor->x - grabsx - grabc->bw,
+ cursor->y - grabsy - grabc->bw,
+ grabc->w, grabc->h);
return;
} else if (cursor_mode == CurResize) {
/*
@@ -916,7 +921,11 @@ resize(Client *c, int x, int y, int w, int h)
{
c->x = x;
c->y = y;
- wlr_xdg_toplevel_set_size(c->xdg_surface, w - 2 * c->bw, h - 2 * c->bw);
+ c->w = w;
+ c->h = h;
+ /* wlroots makes this a no-op if size hasn't changed */
+ wlr_xdg_toplevel_set_size(c->xdg_surface,
+ c->w - 2 * c->bw, c->h - 2 * c->bw);
}
void
@@ -927,13 +936,10 @@ resizemouse(const Arg *arg)
if (!grabc)
return;
- struct wlr_box sbox;
- wlr_xdg_surface_get_geometry(grabc->xdg_surface, &sbox);
/* Doesn't work for X11 output - the next absolute motion event
* returns the cursor to where it started */
wlr_cursor_warp_closest(cursor, NULL,
- grabc->x + sbox.x + sbox.width + 2 * grabc->bw,
- grabc->y + sbox.y + sbox.height + 2 * grabc->bw);
+ grabc->x + grabc->w, grabc->y + grabc->h);
/* Float the window and tell motionnotify to resize it */
if (!grabc->isfloating && selmon->lt[selmon->sellt]->arrange)
@@ -1218,7 +1224,6 @@ tile(Monitor *m)
{
unsigned int i, n = 0, h, mw, my, ty;
Client *c;
- struct wlr_box ca;
wl_list_for_each(c, &clients, link) {
if (VISIBLEON(c, m) && !c->isfloating)
@@ -1235,15 +1240,14 @@ tile(Monitor *m)
wl_list_for_each(c, &clients, link) {
if (!VISIBLEON(c, m) || c->isfloating)
continue;
- wlr_xdg_surface_get_geometry(c->xdg_surface, &ca);
if (i < m->nmaster) {
h = (m->w.height - my) / (MIN(n, m->nmaster) - i);
- resize(c, m->w.x, m->w.y + my, mw, h);
- my += ca.height + 2 * c->bw;
+ resize(c, m->w.x, m->w.y + my, mw, h, 0);
+ my += c->h;
} else {
h = (m->w.height - ty) / (n - i);
- resize(c, m->w.x + mw, m->w.y + ty, m->w.width - mw, h);
- ty += ca.height + 2 * c->bw;
+ resize(c, m->w.x + mw, m->w.y + ty, m->w.width - mw, h, 0);
+ ty += c->h;
}
i++;
}