aewl

changeset 23:95ffdfd0a819

some more additions/fixes
author Anselm R. Garbe <garbeam@wmii.de>
date Wed, 12 Jul 2006 00:00:25 +0200 (2006-07-11)
parents bd3a44353916
children 40b651a26a04
files client.c cmd.c event.c kb.c wm.h
diffstat 5 files changed, 32 insertions(+), 3 deletions(-) [+]
line diff
     1.1 --- a/client.c	Tue Jul 11 23:46:39 2006 +0200
     1.2 +++ b/client.c	Wed Jul 12 00:00:25 2006 +0200
     1.3 @@ -93,6 +93,7 @@
     1.4  	}
     1.5  	XUnmapWindow(dpy, c->title);
     1.6  	draw_bar();
     1.7 +	discard_events(EnterWindowMask);
     1.8  	XFlush(dpy);
     1.9  }
    1.10  
    1.11 @@ -116,7 +117,7 @@
    1.12  	XGetTransientForHint(dpy, c->win, &c->trans);
    1.13  	twa.override_redirect = 1;
    1.14  	twa.background_pixmap = ParentRelative;
    1.15 -	twa.event_mask = SubstructureNotifyMask | ExposureMask;
    1.16 +	twa.event_mask = ExposureMask;
    1.17  
    1.18  	c->title = XCreateWindow(dpy, root, c->tx, c->ty, c->tw, c->th,
    1.19  			0, DefaultDepth(dpy, screen), CopyFromParent,
    1.20 @@ -191,11 +192,19 @@
    1.21  	XFlush(dpy);
    1.22  	XSetErrorHandler(error_handler);
    1.23  	XUngrabServer(dpy);
    1.24 -	discard_events(EnterWindowMask);
    1.25  	if(stack)
    1.26  		focus(stack);
    1.27  }
    1.28  
    1.29 +Client *
    1.30 +gettitle(Window w)
    1.31 +{
    1.32 +	Client *c;
    1.33 +	for(c = clients; c; c = c->next)
    1.34 +		if(c->title == w)
    1.35 +			return c;
    1.36 +	return NULL;
    1.37 +}
    1.38  
    1.39  Client *
    1.40  getclient(Window w)
     2.1 --- a/cmd.c	Tue Jul 11 23:46:39 2006 +0200
     2.2 +++ b/cmd.c	Wed Jul 12 00:00:25 2006 +0200
     2.3 @@ -20,6 +20,22 @@
     2.4  }
     2.5  
     2.6  void
     2.7 +sel(void *aux)
     2.8 +{
     2.9 +	const char *arg = aux;
    2.10 +	Client *c;
    2.11 +
    2.12 +	if(!arg || !stack)
    2.13 +		return;
    2.14 +	if(!strncmp(arg, "next", 5))
    2.15 +		focus(stack->snext ? stack->snext : stack);
    2.16 +	else if(!strncmp(arg, "prev", 5)) {
    2.17 +		for(c = stack; c && c->snext; c = c->snext);
    2.18 +		focus(c ? c : stack);
    2.19 +	}
    2.20 +}
    2.21 +
    2.22 +void
    2.23  kill(void *aux)
    2.24  {
    2.25  	Client *c = stack;
     3.1 --- a/event.c	Tue Jul 11 23:46:39 2006 +0200
     3.2 +++ b/event.c	Wed Jul 12 00:00:25 2006 +0200
     3.3 @@ -146,7 +146,7 @@
     3.4  	Client *c;
     3.5  
     3.6  	if(ev->count == 0) {
     3.7 -		if((c = getclient(ev->window)))
     3.8 +		if((c = gettitle(ev->window)))
     3.9  			draw_client(c);
    3.10  		else if(ev->window == barwin)
    3.11  			draw_bar();
     4.1 --- a/kb.c	Tue Jul 11 23:46:39 2006 +0200
     4.2 +++ b/kb.c	Wed Jul 12 00:00:25 2006 +0200
     4.3 @@ -19,6 +19,8 @@
     4.4  static Key key[] = {
     4.5  	{ Mod1Mask, XK_Return, run, term },
     4.6  	{ Mod1Mask, XK_p, run, proglist }, 
     4.7 +	{ Mod1Mask, XK_k, sel, "prev"}, 
     4.8 +	{ Mod1Mask, XK_j, sel, "next"}, 
     4.9  	{ Mod1Mask | ShiftMask, XK_c, kill, NULL}, 
    4.10  	{ Mod1Mask | ShiftMask, XK_q, quit, NULL},
    4.11  };
     5.1 --- a/wm.h	Tue Jul 11 23:46:39 2006 +0200
     5.2 +++ b/wm.h	Wed Jul 12 00:00:25 2006 +0200
     5.3 @@ -63,6 +63,7 @@
     5.4  extern void run(void *aux);
     5.5  extern void quit(void *aux);
     5.6  extern void kill(void *aux);
     5.7 +extern void sel(void *aux);
     5.8  
     5.9  /* client.c */
    5.10  extern void manage(Window w, XWindowAttributes *wa);
    5.11 @@ -73,6 +74,7 @@
    5.12  extern void draw_client(Client *c);
    5.13  extern void resize(Client *c);
    5.14  extern void update_size(Client *c);
    5.15 +extern Client *gettitle(Window w);
    5.16  
    5.17  /* event.c */
    5.18  extern unsigned int discard_events(long even_mask);