aewl

changeset 124:75576e44c1d8

made status bar drawing more robust, implemented togglemax and togglemode, works quite well
author arg@10ksloc.org
date Thu, 20 Jul 2006 15:07:35 +0200 (2006-07-20)
parents 61490330e90a
children b4b8b4236599
files client.c draw.c dwm.h event.c tag.c
diffstat 5 files changed, 59 insertions(+), 33 deletions(-) [+]
line diff
     1.1 --- a/client.c	Thu Jul 20 12:18:06 2006 +0200
     1.2 +++ b/client.c	Thu Jul 20 15:07:35 2006 +0200
     1.3 @@ -70,6 +70,9 @@
     1.4  	if(!sel)
     1.5  		return;
     1.6  
     1.7 +	if(sel->ismax)
     1.8 +		togglemax(NULL);
     1.9 +
    1.10  	if(!(c = getnext(sel->next, tsel)))
    1.11  		c = getnext(clients, tsel);
    1.12  	if(c) {
    1.13 @@ -87,6 +90,9 @@
    1.14  	if(!sel)
    1.15  		return;
    1.16  
    1.17 +	if(sel->ismax)
    1.18 +		togglemax(NULL);
    1.19 +
    1.20  	if((c = sel->revert && sel->revert->tags[tsel] ? sel->revert : NULL)) {
    1.21  		higher(c);
    1.22  		focus(c);
    1.23 @@ -234,8 +240,6 @@
    1.24  	c->next = clients;
    1.25  	clients = c;
    1.26  
    1.27 -	XGrabButton(dpy, Button1, ControlMask, c->win, False, ButtonPressMask,
    1.28 -			GrabModeAsync, GrabModeSync, None, None);
    1.29  	XGrabButton(dpy, Button1, MODKEY, c->win, False, ButtonPressMask,
    1.30  			GrabModeAsync, GrabModeSync, None, None);
    1.31  	XGrabButton(dpy, Button2, MODKEY, c->win, False, ButtonPressMask,
    1.32 @@ -264,19 +268,6 @@
    1.33  }
    1.34  
    1.35  void
    1.36 -maximize(Arg *arg)
    1.37 -{
    1.38 -	if(!sel)
    1.39 -		return;
    1.40 -	sel->x = sx;
    1.41 -	sel->y = sy + bh;
    1.42 -	sel->w = sw - 2 * sel->border;
    1.43 -	sel->h = sh - 2 * sel->border - bh;
    1.44 -	higher(sel);
    1.45 -	resize(sel, False, TopLeft);
    1.46 -}
    1.47 -
    1.48 -void
    1.49  pop(Client *c)
    1.50  {
    1.51  	Client **l;
    1.52 @@ -405,6 +396,38 @@
    1.53  }
    1.54  
    1.55  void
    1.56 +togglemax(Arg *arg)
    1.57 +{
    1.58 +	int ox, oy, ow, oh;
    1.59 +	XEvent ev;
    1.60 +
    1.61 +	if(!sel)
    1.62 +		return;
    1.63 +
    1.64 +	if((sel->ismax = !sel->ismax)) {
    1.65 +		ox = sel->x;
    1.66 +		oy = sel->y;
    1.67 +		ow = sel->w;
    1.68 +		oh = sel->h;
    1.69 +		sel->x = sx;
    1.70 +		sel->y = sy + bh;
    1.71 +		sel->w = sw - 2 * sel->border;
    1.72 +		sel->h = sh - 2 * sel->border - bh;
    1.73 +
    1.74 +		higher(sel);
    1.75 +		resize(sel, False, TopLeft);
    1.76 +
    1.77 +		sel->x = ox;
    1.78 +		sel->y = oy;
    1.79 +		sel->w = ow;
    1.80 +		sel->h = oh;
    1.81 +	}
    1.82 +	else
    1.83 +		resize(sel, False, TopLeft);
    1.84 +	while(XCheckMaskEvent(dpy, EnterWindowMask, &ev));
    1.85 +}
    1.86 +
    1.87 +void
    1.88  unmanage(Client *c)
    1.89  {
    1.90  	Client **l;
     2.1 --- a/draw.c	Thu Jul 20 12:18:06 2006 +0200
     2.2 +++ b/draw.c	Thu Jul 20 15:07:35 2006 +0200
     2.3 @@ -107,7 +107,7 @@
     2.4  void
     2.5  drawstatus()
     2.6  {
     2.7 -	int i;
     2.8 +	int i, x;
     2.9  	Bool istile = arrange == dotile;
    2.10  
    2.11  	dc.x = dc.y = 0;
    2.12 @@ -123,15 +123,14 @@
    2.13  		else
    2.14  			drawtext(tags[i], (i != tsel), True);
    2.15  	}
    2.16 -	if(sel) {
    2.17 -		dc.x += dc.w;
    2.18 -		dc.w = textw(sel->name);
    2.19 -		drawtext(sel->name, istile, True);
    2.20 -	}
    2.21 +	x = dc.x + dc.w;
    2.22  	dc.w = textw(stext);
    2.23  	dc.x = bx + bw - dc.w;
    2.24  	drawtext(stext, !istile, False);
    2.25 -
    2.26 +	if(sel && ((dc.w = dc.x - x) >= bh)) {
    2.27 +		dc.x = x;
    2.28 +		drawtext(sel->name, istile, True);
    2.29 +	}
    2.30  	XCopyArea(dpy, dc.drawable, barwin, dc.gc, 0, 0, bw, bh, 0, 0);
    2.31  	XSync(dpy, False);
    2.32  }
     3.1 --- a/dwm.h	Thu Jul 20 12:18:06 2006 +0200
     3.2 +++ b/dwm.h	Thu Jul 20 15:07:35 2006 +0200
     3.3 @@ -74,6 +74,7 @@
     3.4  	unsigned int border;
     3.5  	long flags; 
     3.6  	Bool isfloat;
     3.7 +	Bool ismax;
     3.8  	Client *next;
     3.9  	Client *revert;
    3.10  	Window win;
    3.11 @@ -104,11 +105,11 @@
    3.12  extern void killclient(Arg *arg);
    3.13  extern void lower(Client *c);
    3.14  extern void manage(Window w, XWindowAttributes *wa);
    3.15 -extern void maximize(Arg *arg);
    3.16  extern void pop(Client *c);
    3.17  extern void resize(Client *c, Bool inc, Corner sticky);
    3.18  extern void setsize(Client *c);
    3.19  extern void settitle(Client *c);
    3.20 +extern void togglemax(Arg *arg);
    3.21  extern void unmanage(Client *c);
    3.22  extern void zoom(Arg *arg);
    3.23  
    3.24 @@ -137,6 +138,7 @@
    3.25  extern void heretag(Arg *arg);
    3.26  extern void replacetag(Arg *arg);
    3.27  extern void settags(Client *c);
    3.28 +extern void togglemode(Arg *arg);
    3.29  extern void view(Arg *arg);
    3.30  
    3.31  /* util.c */
     4.1 --- a/event.c	Thu Jul 20 12:18:06 2006 +0200
     4.2 +++ b/event.c	Thu Jul 20 15:07:35 2006 +0200
     4.3 @@ -40,8 +40,8 @@
     4.4  	{ MODKEY,		XK_3,		view,		{ .i = Twork } }, 
     4.5  	{ MODKEY,		XK_j,		focusnext,	{ 0 } }, 
     4.6  	{ MODKEY,		XK_k,		focusprev,	{ 0 } },
     4.7 -	{ MODKEY,		XK_m,		maximize,	{ 0 } }, 
     4.8 -	{ MODKEY,		XK_space,	dotile,		{ 0 } }, 
     4.9 +	{ MODKEY,		XK_m,		togglemax,	{ 0 } }, 
    4.10 +	{ MODKEY,		XK_space,	togglemode,	{ 0 } }, 
    4.11  	{ MODKEY,		XK_Return,	zoom,		{ 0 } },
    4.12  	{ ControlMask|ShiftMask,XK_0,		heretag,	{ .i = Tscratch } }, 
    4.13  	{ ControlMask|ShiftMask,XK_1,		heretag,	{ .i = Tdev } }, 
    4.14 @@ -55,7 +55,6 @@
    4.15  	{ MODKEY|ShiftMask,	XK_g,		spawn,		{ .argv = gimp } },
    4.16  	{ MODKEY|ShiftMask,	XK_l,		spawn,		{ .argv = xlock } },
    4.17  	{ MODKEY|ShiftMask,	XK_q,		quit,		{ 0 } },
    4.18 -	{ MODKEY|ShiftMask,	XK_space,	dofloat,	{ 0 } }, 
    4.19  	{ MODKEY|ShiftMask,	XK_w,		spawn,		{ .argv = browse } },
    4.20  	{ MODKEY|ShiftMask,	XK_Return,	spawn,		{ .argv = term } },
    4.21  };
    4.22 @@ -170,11 +169,7 @@
    4.23  		default:
    4.24  			break;
    4.25  		case Button1:
    4.26 -			if(arrange == dotile && !c->isfloat) {
    4.27 -				if((ev->state & ControlMask) && (ev->button == Button1))
    4.28 -					zoom(NULL);
    4.29 -			}
    4.30 -			else {
    4.31 +			if(arrange == dofloat || c->isfloat) {
    4.32  				higher(c);
    4.33  				movemouse(c);
    4.34  			}
     5.1 --- a/tag.c	Thu Jul 20 12:18:06 2006 +0200
     5.2 +++ b/tag.c	Thu Jul 20 15:07:35 2006 +0200
     5.3 @@ -51,8 +51,8 @@
     5.4  {
     5.5  	Client *c;
     5.6  
     5.7 -	arrange = dofloat;
     5.8  	for(c = clients; c; c = c->next) {
     5.9 +		c->ismax = False;
    5.10  		if(c->tags[tsel]) {
    5.11  			resize(c, True, TopLeft);
    5.12  		}
    5.13 @@ -75,7 +75,6 @@
    5.14  	Client *c;
    5.15  
    5.16  	w = sw - mw;
    5.17 -	arrange = dotile;
    5.18  	for(n = 0, c = clients; c; c = c->next)
    5.19  		if(c->tags[tsel] && !c->isfloat)
    5.20  			n++;
    5.21 @@ -86,6 +85,7 @@
    5.22  		h = sh - bh;
    5.23  
    5.24  	for(i = 0, c = clients; c; c = c->next) {
    5.25 +		c->ismax = False;
    5.26  		if(c->tags[tsel]) {
    5.27  			if(c->isfloat) {
    5.28  				higher(c);
    5.29 @@ -213,6 +213,13 @@
    5.30  }
    5.31  
    5.32  void
    5.33 +togglemode(Arg *arg)
    5.34 +{
    5.35 +	arrange = arrange == dofloat ? dotile : dofloat;
    5.36 +	arrange(NULL);
    5.37 +}
    5.38 +
    5.39 +void
    5.40  view(Arg *arg)
    5.41  {
    5.42  	tsel = arg->i;