| 
						
						
							
								
							
						
						
					 | 
				
				 | 
				
					@ -16,7 +16,6 @@ static void destroynotify(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void enternotify(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void leavenotify(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void expose(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void keypress(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void keymapnotify(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void maprequest(XEvent *e); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void propertynotify(XEvent *e); | 
				
			
			
		
	
	
		
			
				
					| 
						
							
								
							
						
						
							
								
							
						
						
					 | 
				
				 | 
				
					@ -47,80 +46,36 @@ flush_masked_events(long even_mask) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					static void | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					configurerequest(XEvent *e) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					{ | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					#if 0 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						XConfigureRequestEvent *ev = &e->xconfigurerequest; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						XWindowChanges wc; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						XRectangle *frect; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						Client *c; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						c = client_of_win(ev->window); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						c = getclient(ev->window); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						ev->value_mask &= ~CWSibling; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						if(c) { | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							gravitate_client(c, True); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							if(ev->value_mask & CWX) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->rect.x = ev->x; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->r[RFloat].x = ev->x; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							if(ev->value_mask & CWY) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->rect.y = ev->y; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->r[RFloat].y = ev->y; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							if(ev->value_mask & CWWidth) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->rect.width = ev->width; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->r[RFloat].width = ev->width; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							if(ev->value_mask & CWHeight) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->rect.height = ev->height; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								c->r[RFloat].height = ev->height; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							if(ev->value_mask & CWBorderWidth) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
								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.y = ev->y; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						wc.width = ev->width; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						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.sibling = None; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						wc.stack_mode = Above; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						ev->value_mask &= ~CWStackMode; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						ev->value_mask |= CWBorderWidth; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						XConfigureWindow(dpy, ev->window, ev->value_mask, &wc); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						XFlush(dpy); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					#endif | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					} | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					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 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					keymapnotify(XEvent *e) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					{ | 
				
			
			
		
	
	
		
			
				
					| 
						
						
						
							
								
							
						
					 | 
				
				 | 
				
					@ -231,7 +160,11 @@ maprequest(XEvent *e) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						} | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						/*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 | 
				
			
			
		
	
	
		
			
				
					| 
						
							
								
							
						
						
						
					 | 
				
				 | 
				
					
  |