From a43d7fb97d3e0d9463b75b78595ccf0eececa007 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 | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'client.c') diff --git a/client.c b/client.c index e4d2644..f6f3d33 100644 --- a/client.c +++ b/client.c @@ -15,7 +15,7 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * - * $OpenBSD: client.c,v 1.238 2017/04/26 21:10:54 okan Exp $ + * $OpenBSD: client.c,v 1.239 2017/05/01 12:54:55 okan Exp $ */ #include @@ -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 v1.2.3-2-gb3c3