Mercurial > aewl
comparison client.c @ 95:5d88952cbf96
implemened distinguishing float/managed geometries of clients (works quite well)
author | Anselm R. Garbe <garbeam@wmii.de> |
---|---|
date | Tue, 18 Jul 2006 12:36:57 +0200 |
parents | 6efe82c775c9 |
children | a19556fe83b5 |
comparison
equal
deleted
inserted
replaced
94:6efe82c775c9 | 95:5d88952cbf96 |
---|---|
14 static void | 14 static void |
15 resizetitle(Client *c) | 15 resizetitle(Client *c) |
16 { | 16 { |
17 int i; | 17 int i; |
18 | 18 |
19 c->tw = 0; | 19 c->bw = 0; |
20 for(i = 0; i < TLast; i++) | 20 for(i = 0; i < TLast; i++) |
21 if(c->tags[i]) | 21 if(c->tags[i]) |
22 c->tw += textw(c->tags[i]); | 22 c->bw += textw(c->tags[i]); |
23 c->tw += textw(c->name); | 23 c->bw += textw(c->name); |
24 if(c->tw > c->w) | 24 if(c->bw > *c->w) |
25 c->tw = c->w + 2; | 25 c->bw = *c->w + 2; |
26 c->tx = c->x + c->w - c->tw + 2; | 26 c->bx = *c->x + *c->w - c->bw + 2; |
27 c->ty = c->y; | 27 c->by = *c->y; |
28 XMoveResizeWindow(dpy, c->title, c->tx, c->ty, c->tw, c->th); | 28 XMoveResizeWindow(dpy, c->title, c->bx, c->by, c->bw, c->bh); |
29 } | 29 } |
30 | 30 |
31 static int | 31 static int |
32 xerrordummy(Display *dsply, XErrorEvent *ee) | 32 xerrordummy(Display *dsply, XErrorEvent *ee) |
33 { | 33 { |
37 /* extern functions */ | 37 /* extern functions */ |
38 | 38 |
39 void | 39 void |
40 ban(Client *c) | 40 ban(Client *c) |
41 { | 41 { |
42 XMoveWindow(dpy, c->win, c->x + 2 * sw, c->y); | 42 XMoveWindow(dpy, c->win, *c->x + 2 * sw, *c->y); |
43 XMoveWindow(dpy, c->title, c->tx + 2 * sw, c->ty); | 43 XMoveWindow(dpy, c->title, c->bx + 2 * sw, c->by); |
44 } | 44 } |
45 | 45 |
46 void | 46 void |
47 focus(Client *c) | 47 focus(Client *c) |
48 { | 48 { |
122 dy = c->border; | 122 dy = c->border; |
123 break; | 123 break; |
124 case EastGravity: | 124 case EastGravity: |
125 case CenterGravity: | 125 case CenterGravity: |
126 case WestGravity: | 126 case WestGravity: |
127 dy = -(c->h / 2) + c->border; | 127 dy = -(*c->h / 2) + c->border; |
128 break; | 128 break; |
129 case SouthEastGravity: | 129 case SouthEastGravity: |
130 case SouthGravity: | 130 case SouthGravity: |
131 case SouthWestGravity: | 131 case SouthWestGravity: |
132 dy = -c->h; | 132 dy = -(*c->h); |
133 break; | 133 break; |
134 default: | 134 default: |
135 break; | 135 break; |
136 } | 136 } |
137 | 137 |
143 dx = c->border; | 143 dx = c->border; |
144 break; | 144 break; |
145 case NorthGravity: | 145 case NorthGravity: |
146 case CenterGravity: | 146 case CenterGravity: |
147 case SouthGravity: | 147 case SouthGravity: |
148 dx = -(c->w / 2) + c->border; | 148 dx = -(*c->w / 2) + c->border; |
149 break; | 149 break; |
150 case NorthEastGravity: | 150 case NorthEastGravity: |
151 case EastGravity: | 151 case EastGravity: |
152 case SouthEastGravity: | 152 case SouthEastGravity: |
153 dx = -(c->w + c->border); | 153 dx = -(*c->w + c->border); |
154 break; | 154 break; |
155 default: | 155 default: |
156 break; | 156 break; |
157 } | 157 } |
158 | 158 |
159 if(invert) { | 159 if(invert) { |
160 dx = -dx; | 160 dx = -dx; |
161 dy = -dy; | 161 dy = -dy; |
162 } | 162 } |
163 c->x += dx; | 163 *c->x += dx; |
164 c->y += dy; | 164 *c->y += dy; |
165 } | 165 } |
166 | 166 |
167 void | 167 void |
168 higher(Client *c) | 168 higher(Client *c) |
169 { | 169 { |
196 XSetWindowAttributes twa; | 196 XSetWindowAttributes twa; |
197 Window trans; | 197 Window trans; |
198 | 198 |
199 c = emallocz(sizeof(Client)); | 199 c = emallocz(sizeof(Client)); |
200 c->win = w; | 200 c->win = w; |
201 c->tx = c->x = wa->x; | 201 c->bx = c->fx = c->tx = wa->x; |
202 c->ty = c->y = wa->y; | 202 c->by = c->fy = c->ty = wa->y; |
203 if(c->y < bh) | 203 if(c->fy < bh) |
204 c->ty = c->y += bh; | 204 c->by = c->fy = c->ty += bh; |
205 c->tw = c->w = wa->width; | 205 c->bw = c->fw = c->tw = wa->width; |
206 c->h = wa->height; | 206 c->fh = c->th = wa->height; |
207 c->th = bh; | 207 c->bh = bh; |
208 c->border = 1; | 208 c->border = 1; |
209 c->proto = getproto(c->win); | 209 c->proto = getproto(c->win); |
210 setsize(c); | 210 setsize(c); |
211 XSelectInput(dpy, c->win, | 211 XSelectInput(dpy, c->win, |
212 StructureNotifyMask | PropertyChangeMask | EnterWindowMask); | 212 StructureNotifyMask | PropertyChangeMask | EnterWindowMask); |
213 XGetTransientForHint(dpy, c->win, &trans); | 213 XGetTransientForHint(dpy, c->win, &trans); |
214 twa.override_redirect = 1; | 214 twa.override_redirect = 1; |
215 twa.background_pixmap = ParentRelative; | 215 twa.background_pixmap = ParentRelative; |
216 twa.event_mask = ExposureMask; | 216 twa.event_mask = ExposureMask; |
217 | 217 |
218 c->title = XCreateWindow(dpy, root, c->tx, c->ty, c->tw, c->th, | 218 c->title = XCreateWindow(dpy, root, c->bx, c->by, c->bw, c->bh, |
219 0, DefaultDepth(dpy, screen), CopyFromParent, | 219 0, DefaultDepth(dpy, screen), CopyFromParent, |
220 DefaultVisual(dpy, screen), | 220 DefaultVisual(dpy, screen), |
221 CWOverrideRedirect | CWBackPixmap | CWEventMask, &twa); | 221 CWOverrideRedirect | CWBackPixmap | CWEventMask, &twa); |
222 | 222 |
223 settitle(c); | |
224 settags(c); | 223 settags(c); |
225 | 224 |
226 c->next = clients; | 225 c->next = clients; |
227 clients = c; | 226 clients = c; |
228 | 227 |
237 | 236 |
238 if(!c->isfloat) | 237 if(!c->isfloat) |
239 c->isfloat = trans | 238 c->isfloat = trans |
240 || ((c->maxw == c->minw) && (c->maxh == c->minh)); | 239 || ((c->maxw == c->minw) && (c->maxh == c->minh)); |
241 | 240 |
241 setgeom(c); | |
242 settitle(c); | |
243 | |
242 arrange(NULL); | 244 arrange(NULL); |
245 | |
243 /* mapping the window now prevents flicker */ | 246 /* mapping the window now prevents flicker */ |
244 if(c->tags[tsel]) { | 247 if(c->tags[tsel]) { |
245 XMapRaised(dpy, c->win); | 248 XMapRaised(dpy, c->win); |
246 XMapRaised(dpy, c->title); | 249 XMapRaised(dpy, c->title); |
247 focus(c); | 250 focus(c); |
257 void | 260 void |
258 maximize(Arg *arg) | 261 maximize(Arg *arg) |
259 { | 262 { |
260 if(!sel) | 263 if(!sel) |
261 return; | 264 return; |
262 sel->x = sx; | 265 *sel->x = sx; |
263 sel->y = sy + bh; | 266 *sel->y = sy + bh; |
264 sel->w = sw - 2 * sel->border; | 267 *sel->w = sw - 2 * sel->border; |
265 sel->h = sh - 2 * sel->border - bh; | 268 *sel->h = sh - 2 * sel->border - bh; |
266 higher(sel); | 269 higher(sel); |
267 resize(sel, False); | 270 resize(sel, False); |
268 } | 271 } |
269 | 272 |
270 void | 273 void |
284 { | 287 { |
285 XConfigureEvent e; | 288 XConfigureEvent e; |
286 | 289 |
287 if(inc) { | 290 if(inc) { |
288 if(c->incw) | 291 if(c->incw) |
289 c->w -= (c->w - c->basew) % c->incw; | 292 *c->w -= (*c->w - c->basew) % c->incw; |
290 if(c->inch) | 293 if(c->inch) |
291 c->h -= (c->h - c->baseh) % c->inch; | 294 *c->h -= (*c->h - c->baseh) % c->inch; |
292 } | 295 } |
293 if(c->x > sw) /* might happen on restart */ | 296 if(*c->x > sw) /* might happen on restart */ |
294 c->x = sw - c->w; | 297 *c->x = sw - *c->w; |
295 if(c->y > sh) | 298 if(*c->y > sh) |
296 c->ty = c->y = sh - c->h; | 299 *c->y = sh - *c->h; |
297 if(c->minw && c->w < c->minw) | 300 if(c->minw && *c->w < c->minw) |
298 c->w = c->minw; | 301 *c->w = c->minw; |
299 if(c->minh && c->h < c->minh) | 302 if(c->minh && *c->h < c->minh) |
300 c->h = c->minh; | 303 *c->h = c->minh; |
301 if(c->maxw && c->w > c->maxw) | 304 if(c->maxw && *c->w > c->maxw) |
302 c->w = c->maxw; | 305 *c->w = c->maxw; |
303 if(c->maxh && c->h > c->maxh) | 306 if(c->maxh && *c->h > c->maxh) |
304 c->h = c->maxh; | 307 *c->h = c->maxh; |
305 resizetitle(c); | 308 resizetitle(c); |
306 XSetWindowBorderWidth(dpy, c->win, 1); | 309 XSetWindowBorderWidth(dpy, c->win, 1); |
307 XMoveResizeWindow(dpy, c->win, c->x, c->y, c->w, c->h); | 310 XMoveResizeWindow(dpy, c->win, *c->x, *c->y, *c->w, *c->h); |
308 e.type = ConfigureNotify; | 311 e.type = ConfigureNotify; |
309 e.event = c->win; | 312 e.event = c->win; |
310 e.window = c->win; | 313 e.window = c->win; |
311 e.x = c->x; | 314 e.x = *c->x; |
312 e.y = c->y; | 315 e.y = *c->y; |
313 e.width = c->w; | 316 e.width = *c->w; |
314 e.height = c->h; | 317 e.height = *c->h; |
315 e.border_width = c->border; | 318 e.border_width = c->border; |
316 e.above = None; | 319 e.above = None; |
317 e.override_redirect = False; | 320 e.override_redirect = False; |
318 XSendEvent(dpy, c->win, False, StructureNotifyMask, (XEvent *)&e); | 321 XSendEvent(dpy, c->win, False, StructureNotifyMask, (XEvent *)&e); |
319 XSync(dpy, False); | 322 XSync(dpy, False); |
323 } | |
324 | |
325 void | |
326 setgeom(Client *c) | |
327 { | |
328 if((arrange == dotile) && !c->isfloat) { | |
329 c->x = &c->tx; | |
330 c->y = &c->ty; | |
331 c->w = &c->tw; | |
332 c->h = &c->th; | |
333 } | |
334 else { | |
335 c->x = &c->fx; | |
336 c->y = &c->fy; | |
337 c->w = &c->fw; | |
338 c->h = &c->fh; | |
339 } | |
320 } | 340 } |
321 | 341 |
322 void | 342 void |
323 setsize(Client *c) | 343 setsize(Client *c) |
324 { | 344 { |