about summary refs log tree commit diff stats
path: root/event.c
diff options
context:
space:
mode:
Diffstat (limited to 'event.c')
-rw-r--r--event.c56
1 files changed, 37 insertions, 19 deletions
diff --git a/event.c b/event.c
index d5f4aa8..1939cd5 100644
--- a/event.c
+++ b/event.c
@@ -21,6 +21,23 @@ KEYS
 #define CLEANMASK(mask) (mask & ~(numlockmask | LockMask))
 
 static void
+synconfig(Client *c, int x, int y, int w, int h, unsigned int border) {
+	XEvent synev;
+
+	synev.type = ConfigureNotify;
+	synev.xconfigure.display = dpy;
+	synev.xconfigure.event = c->win;
+	synev.xconfigure.window = c->win;
+	synev.xconfigure.x = x;
+	synev.xconfigure.y = y;
+	synev.xconfigure.width = w;
+	synev.xconfigure.height = h;
+	synev.xconfigure.border_width = border;
+	synev.xconfigure.above = None;
+	XSendEvent(dpy, c->win, True, NoEventMask, &synev);
+}
+
+static void
 movemouse(Client *c) {
 	int x1, y1, ocx, ocy, di;
 	unsigned int dui;
@@ -34,10 +51,14 @@ movemouse(Client *c) {
 		return;
 	XQueryPointer(dpy, root, &dummy, &dummy, &x1, &y1, &di, &di, &dui);
 	for(;;) {
-		XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
+		XMaskEvent(dpy, MOUSEMASK | ExposureMask | StructureNotifyMask, &ev);
 		switch (ev.type) {
 		default:
 			break;
+		case ConfigureRequest:
+			synconfig(c, c->x, c->y, c->w, c->h, ev.xconfigure.border_width);
+			XSync(dpy, False);
+			break;
 		case Expose:
 			handler[Expose](&ev);
 			break;
@@ -50,6 +71,11 @@ movemouse(Client *c) {
 		case ButtonRelease:
 			XUngrabPointer(dpy, CurrentTime);
 			return;
+		case DestroyNotify:
+		case UnmapNotify:
+			XUngrabPointer(dpy, CurrentTime);
+			handler[ev.type](&ev);
+			return;
 		}
 	}
 }
@@ -68,10 +94,14 @@ resizemouse(Client *c) {
 		return;
 	XWarpPointer(dpy, None, c->win, 0, 0, 0, 0, c->w, c->h);
 	for(;;) {
-		XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
+		XMaskEvent(dpy, MOUSEMASK | ExposureMask | StructureNotifyMask, &ev);
 		switch(ev.type) {
 		default:
 			break;
+		case ConfigureRequest:
+			synconfig(c, c->x, c->y, c->w, c->h, ev.xconfigure.border_width);
+			XSync(dpy, False);
+			break;
 		case Expose:
 			handler[Expose](&ev);
 			break;
@@ -92,6 +122,11 @@ resizemouse(Client *c) {
 		case ButtonRelease:
 			XUngrabPointer(dpy, CurrentTime);
 			return;
+		case DestroyNotify:
+		case UnmapNotify:
+			XUngrabPointer(dpy, CurrentTime);
+			handler[ev.type](&ev);
+			return;
 		}
 	}
 }
@@ -146,23 +181,6 @@ buttonpress(XEvent *e) {
 }
 
 static void
-synconfig(Client *c, int x, int y, int w, int h, unsigned int border) {
-	XEvent synev;
-
-	synev.type = ConfigureNotify;
-	synev.xconfigure.display = dpy;
-	synev.xconfigure.event = c->win;
-	synev.xconfigure.window = c->win;
-	synev.xconfigure.x = x;
-	synev.xconfigure.y = y;
-	synev.xconfigure.width = w;
-	synev.xconfigure.height = h;
-	synev.xconfigure.border_width = border;
-	synev.xconfigure.above = None;
-	XSendEvent(dpy, c->win, True, NoEventMask, &synev);
-}
-
-static void
 configurerequest(XEvent *e) {
 	unsigned long newmask;
 	Client *c;
Utils.h?id=e087f6d44e87f489fcb3056e86319ebba4218156'>e087f6d4
e087f6d4
e087f6d4
e087f6d4

c3ec4181 ^
e087f6d4




c3ec4181 ^

e087f6d4
6bd78b38 ^

e087f6d4
c3ec4181 ^
86b4d41a ^
c3ec4181 ^
86b4d41a ^
57bfc74f ^
e4409c40 ^
c3ec4181 ^
e4409c40 ^
e087f6d4
549ec595 ^


b63d287c ^


c3ec4181 ^

e087f6d4



c3ec4181 ^




e087f6d4




























6f662196 ^

e087f6d4
6f662196 ^






c3ec4181 ^
6f662196 ^
e087f6d4
6f662196 ^
e087f6d4
c3ec4181 ^



e087f6d4
c3ec4181 ^








e087f6d4




549ec595 ^


e087f6d4
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145