From 3d6ff6dabfba7bb863970a7780c3e6ba19f06612 Mon Sep 17 00:00:00 2001 From: okan Date: Mon, 1 May 2017 12:54:55 +0000 Subject: Clean up, unify and accurately calculate edge distance with client move/resize actions, so as to not lose windows off the edge. inspired by diffs (and feedback) from Vadim Vygonets. --- client.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'client.c') diff --git a/client.c b/client.c index e013d30..72f0183 100644 --- a/client.c +++ b/client.c @@ -470,6 +470,24 @@ client_config(struct client_ctx *cc) XSendEvent(X_Dpy, cc->win, False, StructureNotifyMask, (XEvent *)&cn); } +void +client_ptr_inbound(struct client_ctx *cc, int getpos) +{ + if (getpos) + xu_ptr_getpos(cc->win, &cc->ptr.x, &cc->ptr.y); + + if (cc->ptr.x < 0) + cc->ptr.x = 0; + else if (cc->ptr.x > cc->geom.w - 1) + cc->ptr.x = cc->geom.w - 1; + if (cc->ptr.y < 0) + cc->ptr.y = 0; + else if (cc->ptr.y > cc->geom.h - 1) + cc->ptr.y = cc->geom.h - 1; + + client_ptrwarp(cc); +} + void client_ptrwarp(struct client_ctx *cc) { -- cgit 1.4.1