aboutsummaryrefslogtreecommitdiffstats
path: root/client.c
diff options
context:
space:
mode:
authorokan2016-09-30 20:55:54 +0000
committerokan2016-09-30 20:55:54 +0000
commit63bd68d743b249f434a44bb3d410f6f516952be6 (patch)
treeaf9854b54b6f410de7ebb63b6700726f3ada9aa5 /client.c
parent3c9ef4366fd228c7272aa4f467ee4f7ecadf2049 (diff)
downloadcwm-63bd68d743b249f434a44bb3d410f6f516952be6.tar.gz
Set the initial ptr position during client init, instead of waiting
until (maybe) a ptrwarp call. Likewise, explicitly ensure an inbounds ptr position (same as initial) when saving.
Diffstat (limited to 'client.c')
-rw-r--r--client.c21
1 files changed, 8 insertions, 13 deletions
diff --git a/client.c b/client.c
index 62ebc36..5797135 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.224 2016/09/20 19:11:19 okan Exp $
+ * $OpenBSD: client.c,v 1.225 2016/09/30 20:55:54 okan Exp $
*/
#include <sys/types.h>
@@ -75,8 +75,6 @@ client_init(Window win, struct screen_ctx *sc, int active)
cc->stackingorder = 0;
memset(&cc->hint, 0, sizeof(cc->hint));
memset(&cc->ch, 0, sizeof(cc->ch));
- cc->ptr.x = -1;
- cc->ptr.y = -1;
TAILQ_INIT(&cc->nameq);
client_setname(cc);
@@ -93,6 +91,9 @@ client_init(Window win, struct screen_ctx *sc, int active)
cc->geom.y = wattr.y;
cc->geom.w = wattr.width;
cc->geom.h = wattr.height;
+ cc->ptr.x = cc->geom.w / 2;
+ cc->ptr.y = cc->geom.h / 2;
+
cc->colormap = wattr.colormap;
if (wattr.map_state != IsViewable) {
@@ -468,18 +469,12 @@ client_config(struct client_ctx *cc)
void
client_ptrwarp(struct client_ctx *cc)
{
- int x = cc->ptr.x, y = cc->ptr.y;
-
- if (x == -1 || y == -1) {
- x = cc->geom.w / 2;
- y = cc->geom.h / 2;
- }
-
if (cc->flags & CLIENT_HIDDEN)
client_unhide(cc);
else
client_raise(cc);
- xu_ptr_setpos(cc->win, x, y);
+
+ xu_ptr_setpos(cc->win, cc->ptr.x, cc->ptr.y);
}
void
@@ -492,8 +487,8 @@ client_ptrsave(struct client_ctx *cc)
cc->ptr.x = x;
cc->ptr.y = y;
} else {
- cc->ptr.x = -1;
- cc->ptr.y = -1;
+ cc->ptr.x = cc->geom.w / 2;
+ cc->ptr.y = cc->geom.h / 2;
}
}