| 
																	
																	
																		
																			
																		
																	
																	
																 | 
																@ -16,7 +16,6 @@ static void destroynotify(XEvent *e); | 
															
														
														
													
														
															
																 | 
																 | 
																static void enternotify(XEvent *e); | 
																 | 
																 | 
																static void enternotify(XEvent *e); | 
															
														
														
													
														
															
																 | 
																 | 
																static void leavenotify(XEvent *e); | 
																 | 
																 | 
																static void leavenotify(XEvent *e); | 
															
														
														
													
														
															
																 | 
																 | 
																static void expose(XEvent *e); | 
																 | 
																 | 
																static void expose(XEvent *e); | 
															
														
														
													
														
															
																 | 
																 | 
																static void keypress(XEvent *e); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																static void keymapnotify(XEvent *e); | 
																 | 
																 | 
																static void keymapnotify(XEvent *e); | 
															
														
														
													
														
															
																 | 
																 | 
																static void maprequest(XEvent *e); | 
																 | 
																 | 
																static void maprequest(XEvent *e); | 
															
														
														
													
														
															
																 | 
																 | 
																static void propertynotify(XEvent *e); | 
																 | 
																 | 
																static void propertynotify(XEvent *e); | 
															
														
														
													
												
													
														
															
																| 
																	
																		
																			
																		
																	
																	
																		
																			
																		
																	
																	
																 | 
																@ -47,80 +46,36 @@ flush_masked_events(long even_mask) | 
															
														
														
													
														
															
																 | 
																 | 
																static void | 
																 | 
																 | 
																static void | 
															
														
														
													
														
															
																 | 
																 | 
																configurerequest(XEvent *e) | 
																 | 
																 | 
																configurerequest(XEvent *e) | 
															
														
														
													
														
															
																 | 
																 | 
																{ | 
																 | 
																 | 
																{ | 
															
														
														
													
														
															
																 | 
																 | 
																#if 0 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	XConfigureRequestEvent *ev = &e->xconfigurerequest; | 
																 | 
																 | 
																	XConfigureRequestEvent *ev = &e->xconfigurerequest; | 
															
														
														
													
														
															
																 | 
																 | 
																	XWindowChanges wc; | 
																 | 
																 | 
																	XWindowChanges wc; | 
															
														
														
													
														
															
																 | 
																 | 
																	XRectangle *frect; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	Client *c; | 
																 | 
																 | 
																	Client *c; | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																
 | 
															
														
														
													
														
															
																 | 
																 | 
																	c = client_of_win(ev->window); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																	c = getclient(ev->window); | 
															
														
														
													
														
															
																 | 
																 | 
																	ev->value_mask &= ~CWSibling; | 
																 | 
																 | 
																	ev->value_mask &= ~CWSibling; | 
															
														
														
													
														
															
																 | 
																 | 
																	if(c) { | 
																 | 
																 | 
																	if(c) { | 
															
														
														
													
														
															
																 | 
																 | 
																		gravitate_client(c, True); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		if(ev->value_mask & CWX) | 
																 | 
																 | 
																		if(ev->value_mask & CWX) | 
															
														
														
													
														
															
																 | 
																 | 
																			c->rect.x = ev->x; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																			c->r[RFloat].x = ev->x; | 
															
														
														
													
														
															
																 | 
																 | 
																		if(ev->value_mask & CWY) | 
																 | 
																 | 
																		if(ev->value_mask & CWY) | 
															
														
														
													
														
															
																 | 
																 | 
																			c->rect.y = ev->y; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																			c->r[RFloat].y = ev->y; | 
															
														
														
													
														
															
																 | 
																 | 
																		if(ev->value_mask & CWWidth) | 
																 | 
																 | 
																		if(ev->value_mask & CWWidth) | 
															
														
														
													
														
															
																 | 
																 | 
																			c->rect.width = ev->width; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																			c->r[RFloat].width = ev->width; | 
															
														
														
													
														
															
																 | 
																 | 
																		if(ev->value_mask & CWHeight) | 
																 | 
																 | 
																		if(ev->value_mask & CWHeight) | 
															
														
														
													
														
															
																 | 
																 | 
																			c->rect.height = ev->height; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																			c->r[RFloat].height = ev->height; | 
															
														
														
													
														
															
																 | 
																 | 
																		if(ev->value_mask & CWBorderWidth) | 
																 | 
																 | 
																		if(ev->value_mask & CWBorderWidth) | 
															
														
														
													
														
															
																 | 
																 | 
																			c->border = ev->border_width; | 
																 | 
																 | 
																			c->border = ev->border_width; | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		gravitate_client(c, False); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		if(c->frame) { | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			if(c->sel->area->floating) | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				frect=&c->sel->rect; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			else | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				frect=&c->sel->revert; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			if(c->rect.width >= screen->rect.width && c->rect.height >= screen->rect.height) { | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				frect->y = wc.y = -height_of_bar(); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				frect->x = wc.x = -def.border; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			else { | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				frect->y = wc.y = c->rect.y - height_of_bar(); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				frect->x = wc.x = c->rect.x - def.border; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			frect->width = wc.width = c->rect.width + 2 * def.border; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			frect->height = wc.height = c->rect.height + def.border | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				+ height_of_bar(); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			wc.border_width = 1; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			wc.sibling = None; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			wc.stack_mode = ev->detail; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			if(c->sel->area->view != screen->sel) | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				wc.x += 2 * screen->rect.width; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			if(c->sel->area->floating) { | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				XConfigureWindow(dpy, c->framewin, ev->value_mask, &wc); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				configure_client(c); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	} | 
																 | 
																 | 
																	} | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																
 | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.x = ev->x; | 
																 | 
																 | 
																	wc.x = ev->x; | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.y = ev->y; | 
																 | 
																 | 
																	wc.y = ev->y; | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.width = ev->width; | 
																 | 
																 | 
																	wc.width = ev->width; | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.height = ev->height; | 
																 | 
																 | 
																	wc.height = ev->height; | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	if(c && c->frame) { | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		wc.x = def.border; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		wc.y = height_of_bar(); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		wc.width = c->sel->rect.width - 2 * def.border; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		wc.height = c->sel->rect.height - def.border - height_of_bar(); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.border_width = 0; | 
																 | 
																 | 
																	wc.border_width = 0; | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.sibling = None; | 
																 | 
																 | 
																	wc.sibling = None; | 
															
														
														
													
														
															
																 | 
																 | 
																	wc.stack_mode = Above; | 
																 | 
																 | 
																	wc.stack_mode = Above; | 
															
														
														
													
														
															
																 | 
																 | 
																	ev->value_mask &= ~CWStackMode; | 
																 | 
																 | 
																	ev->value_mask &= ~CWStackMode; | 
															
														
														
													
														
															
																 | 
																 | 
																	ev->value_mask |= CWBorderWidth; | 
																 | 
																 | 
																	ev->value_mask |= CWBorderWidth; | 
															
														
														
													
														
															
																 | 
																 | 
																	XConfigureWindow(dpy, ev->window, ev->value_mask, &wc); | 
																 | 
																 | 
																	XConfigureWindow(dpy, ev->window, ev->value_mask, &wc); | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	XFlush(dpy); | 
																 | 
																 | 
																	XFlush(dpy); | 
															
														
														
													
														
															
																 | 
																 | 
																#endif | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																} | 
																 | 
																 | 
																} | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																
 | 
															
														
														
													
														
															
																 | 
																 | 
																static void | 
																 | 
																 | 
																static void | 
															
														
														
													
												
													
														
															
																| 
																	
																		
																			
																		
																	
																	
																		
																			
																		
																	
																	
																 | 
																@ -181,32 +136,6 @@ expose(XEvent *e) | 
															
														
														
													
														
															
																 | 
																 | 
																	} | 
																 | 
																 | 
																	} | 
															
														
														
													
														
															
																 | 
																 | 
																} | 
																 | 
																 | 
																} | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																
 | 
															
														
														
													
														
															
																 | 
																 | 
																static void | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																keypress(XEvent *e) | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																{ | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																#if 0 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	XKeyEvent *ev = &e->xkey; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	KeySym k = 0; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	char buf[32]; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	int n; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	static Frame *f; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	ev->state &= valid_mask; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	if((f = frame_of_win(ev->window))) { | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		buf[0] = 0; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		n = XLookupString(ev, buf, sizeof(buf), &k, 0); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		if(IsFunctionKey(k) || IsKeypadKey(k) || IsMiscFunctionKey(k) | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																				|| IsPFKey(k) || IsPrivateKeypadKey(k)) | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																			return; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		buf[n] = 0; | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		blitz_kpress_input(&f->tagbar, ev->state, k, buf); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																	else | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																		key(root, ev->state, (KeyCode) ev->keycode); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																#endif | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																} | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																static void | 
																 | 
																 | 
																static void | 
															
														
														
													
														
															
																 | 
																 | 
																keymapnotify(XEvent *e) | 
																 | 
																 | 
																keymapnotify(XEvent *e) | 
															
														
														
													
														
															
																 | 
																 | 
																{ | 
																 | 
																 | 
																{ | 
															
														
														
													
												
													
														
															
																| 
																	
																	
																	
																		
																			
																		
																	
																 | 
																@ -231,7 +160,11 @@ maprequest(XEvent *e) | 
															
														
														
													
														
															
																 | 
																 | 
																	} | 
																 | 
																 | 
																	} | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																
 | 
															
														
														
													
														
															
																 | 
																 | 
																	/*if(!client_of_win(ev->window))*/ | 
																 | 
																 | 
																	/*if(!client_of_win(ev->window))*/ | 
															
														
														
													
														
															
																 | 
																 | 
																		manage(create_client(ev->window, &wa)); | 
																 | 
																 | 
																 | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																		/*manage(create_client(ev->window, &wa));*/ | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																	XMapRaised(dpy, ev->window); | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																	XMoveResizeWindow(dpy, ev->window, rect.x, rect.y, rect.width, rect.height - barrect.height); | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																	XSetInputFocus(dpy, ev->window, RevertToPointerRoot, CurrentTime); | 
															
														
														
													
														
															
																 | 
																 | 
																 | 
																 | 
																 | 
																	XFlush(dpy); | 
															
														
														
													
														
															
																 | 
																 | 
																} | 
																 | 
																 | 
																} | 
															
														
														
													
														
															
																 | 
																 | 
																
 | 
																 | 
																 | 
																
 | 
															
														
														
													
														
															
																 | 
																 | 
																static void | 
																 | 
																 | 
																static void | 
															
														
														
													
												
													
														
															
																| 
																	
																		
																			
																		
																	
																	
																	
																 | 
																
  |