applied Mate's patch, added Mate to LICENSE
This commit is contained in:
		
							
								
								
									
										1
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -10,6 +10,7 @@ MIT/X Consortium License | |||||||
| © 2007-2008 Peter Hartlich <sgkkr at hartlich dot com> | © 2007-2008 Peter Hartlich <sgkkr at hartlich dot com> | ||||||
| © 2008 Martin Hurton <martin dot hurton at gmail dot com> | © 2008 Martin Hurton <martin dot hurton at gmail dot com> | ||||||
| © 2008 Neale Pickett <neale dot woozle dot org> | © 2008 Neale Pickett <neale dot woozle dot org> | ||||||
|  | © 2009 Mate Nagy <mnagy@port70.net> | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a | Permission is hereby granted, free of charge, to any person obtaining a | ||||||
| copy of this software and associated documentation files (the "Software"), | copy of this software and associated documentation files (the "Software"), | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								dwm.c
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								dwm.c
									
									
									
									
									
								
							| @@ -136,6 +136,7 @@ struct Monitor { | |||||||
| 	Client *stack; | 	Client *stack; | ||||||
| 	Monitor *next; | 	Monitor *next; | ||||||
| 	Window barwin; | 	Window barwin; | ||||||
|  | 	Layout *lt[2]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| typedef struct { | typedef struct { | ||||||
| @@ -261,7 +262,6 @@ static Bool running = True; | |||||||
| static Cursor cursor[CurLast]; | static Cursor cursor[CurLast]; | ||||||
| static Display *dpy; | static Display *dpy; | ||||||
| static DC dc; | static DC dc; | ||||||
| static Layout *lt[] = { NULL, NULL }; |  | ||||||
| static Monitor *mons = NULL, *selmon = NULL; | static Monitor *mons = NULL, *selmon = NULL; | ||||||
| static Window root; | static Window root; | ||||||
|  |  | ||||||
| @@ -376,8 +376,8 @@ arrange(void) { | |||||||
| 		showhide(m->stack); | 		showhide(m->stack); | ||||||
| 	focus(NULL); | 	focus(NULL); | ||||||
| 	for(m = mons; m; m = m->next) { | 	for(m = mons; m; m = m->next) { | ||||||
| 		if(lt[m->sellt]->arrange) | 		if(m->lt[m->sellt]->arrange) | ||||||
| 			lt[m->sellt]->arrange(m); | 			m->lt[m->sellt]->arrange(m); | ||||||
| 		restack(m); | 		restack(m); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @@ -456,7 +456,7 @@ cleanup(void) { | |||||||
| 	Monitor *m; | 	Monitor *m; | ||||||
|  |  | ||||||
| 	view(&a); | 	view(&a); | ||||||
| 	lt[selmon->sellt] = &foo; | 	selmon->lt[selmon->sellt] = &foo; | ||||||
| 	for(m = mons; m; m = m->next) | 	for(m = mons; m; m = m->next) | ||||||
| 		while(m->stack) | 		while(m->stack) | ||||||
| 			unmanage(m->stack); | 			unmanage(m->stack); | ||||||
| @@ -547,7 +547,7 @@ configurerequest(XEvent *e) { | |||||||
| 	if((c = wintoclient(ev->window))) { | 	if((c = wintoclient(ev->window))) { | ||||||
| 		if(ev->value_mask & CWBorderWidth) | 		if(ev->value_mask & CWBorderWidth) | ||||||
| 			c->bw = ev->border_width; | 			c->bw = ev->border_width; | ||||||
| 		else if(c->isfloating || !lt[selmon->sellt]->arrange) { | 		else if(c->isfloating || !selmon->lt[selmon->sellt]->arrange) { | ||||||
| 			m = c->mon; | 			m = c->mon; | ||||||
| 			if(ev->value_mask & CWX) | 			if(ev->value_mask & CWX) | ||||||
| 				c->x = m->mx + ev->x; | 				c->x = m->mx + ev->x; | ||||||
| @@ -668,7 +668,7 @@ drawbar(Monitor *m) { | |||||||
| 	} | 	} | ||||||
| 	if(blw > 0) { | 	if(blw > 0) { | ||||||
| 		dc.w = blw; | 		dc.w = blw; | ||||||
| 		drawtext(lt[m->sellt]->symbol, dc.norm, False); | 		drawtext(m->lt[m->sellt]->symbol, dc.norm, False); | ||||||
| 		x = dc.x + dc.w; | 		x = dc.x + dc.w; | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| @@ -1170,11 +1170,11 @@ movemouse(const Arg *arg) { | |||||||
| 					ny = selmon->wy; | 					ny = selmon->wy; | ||||||
| 				else if(abs((selmon->wy + selmon->wh) - (ny + HEIGHT(c))) < snap) | 				else if(abs((selmon->wy + selmon->wh) - (ny + HEIGHT(c))) < snap) | ||||||
| 					ny = selmon->wy + selmon->wh - HEIGHT(c); | 					ny = selmon->wy + selmon->wh - HEIGHT(c); | ||||||
| 				if(!c->isfloating && lt[selmon->sellt]->arrange | 				if(!c->isfloating && selmon->lt[selmon->sellt]->arrange | ||||||
| 				                  && (abs(nx - c->x) > snap || abs(ny - c->y) > snap)) | 				                  && (abs(nx - c->x) > snap || abs(ny - c->y) > snap)) | ||||||
| 					togglefloating(NULL); | 					togglefloating(NULL); | ||||||
| 			} | 			} | ||||||
| 			if(!lt[selmon->sellt]->arrange || c->isfloating) | 			if(!selmon->lt[selmon->sellt]->arrange || c->isfloating) | ||||||
| 				resize(c, nx, ny, c->w, c->h, True); | 				resize(c, nx, ny, c->w, c->h, True); | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| @@ -1289,11 +1289,11 @@ resizemouse(const Arg *arg) { | |||||||
| 			nh = MAX(ev.xmotion.y - ocy - 2 * c->bw + 1, 1); | 			nh = MAX(ev.xmotion.y - ocy - 2 * c->bw + 1, 1); | ||||||
| 			if(snap && nw >= selmon->wx && nw <= selmon->wx + selmon->ww | 			if(snap && nw >= selmon->wx && nw <= selmon->wx + selmon->ww | ||||||
| 			        && nh >= selmon->wy && nh <= selmon->wy + selmon->wh) { | 			        && nh >= selmon->wy && nh <= selmon->wy + selmon->wh) { | ||||||
| 				if(!c->isfloating && lt[selmon->sellt]->arrange | 				if(!c->isfloating && selmon->lt[selmon->sellt]->arrange | ||||||
| 				   && (abs(nw - c->w) > snap || abs(nh - c->h) > snap)) | 				   && (abs(nw - c->w) > snap || abs(nh - c->h) > snap)) | ||||||
| 					togglefloating(NULL); | 					togglefloating(NULL); | ||||||
| 			} | 			} | ||||||
| 			if(!lt[selmon->sellt]->arrange || c->isfloating) | 			if(!selmon->lt[selmon->sellt]->arrange || c->isfloating) | ||||||
| 				resize(c, c->x, c->y, nw, nh, True); | 				resize(c, c->x, c->y, nw, nh, True); | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| @@ -1318,9 +1318,9 @@ restack(Monitor *m) { | |||||||
| 	drawbars(); | 	drawbars(); | ||||||
| 	if(!m->sel) | 	if(!m->sel) | ||||||
| 		return; | 		return; | ||||||
| 	if(m->sel->isfloating || !lt[m->sellt]->arrange) | 	if(m->sel->isfloating || !m->lt[m->sellt]->arrange) | ||||||
| 		XRaiseWindow(dpy, m->sel->win); | 		XRaiseWindow(dpy, m->sel->win); | ||||||
| 	if(lt[m->sellt]->arrange) { | 	if(m->lt[m->sellt]->arrange) { | ||||||
| 		wc.stack_mode = Below; | 		wc.stack_mode = Below; | ||||||
| 		wc.sibling = m->barwin; | 		wc.sibling = m->barwin; | ||||||
| 		for(c = m->stack; c; c = c->snext) | 		for(c = m->stack; c; c = c->snext) | ||||||
| @@ -1396,10 +1396,10 @@ setclientstate(Client *c, long state) { | |||||||
|  |  | ||||||
| void | void | ||||||
| setlayout(const Arg *arg) { | setlayout(const Arg *arg) { | ||||||
| 	if(!arg || !arg->v || arg->v != lt[selmon->sellt]) | 	if(!arg || !arg->v || arg->v != selmon->lt[selmon->sellt]) | ||||||
| 		selmon->sellt ^= 1; | 		selmon->sellt ^= 1; | ||||||
| 	if(arg && arg->v) | 	if(arg && arg->v) | ||||||
| 		lt[selmon->sellt] = (Layout *)arg->v; | 		selmon->lt[selmon->sellt] = (Layout *)arg->v; | ||||||
| 	if(selmon->sel) | 	if(selmon->sel) | ||||||
| 		arrange(); | 		arrange(); | ||||||
| 	else | 	else | ||||||
| @@ -1411,7 +1411,7 @@ void | |||||||
| setmfact(const Arg *arg) { | setmfact(const Arg *arg) { | ||||||
| 	float f; | 	float f; | ||||||
|  |  | ||||||
| 	if(!arg || !lt[selmon->sellt]->arrange) | 	if(!arg || !selmon->lt[selmon->sellt]->arrange) | ||||||
| 		return; | 		return; | ||||||
| 	f = arg->f < 1.0 ? arg->f + selmon->mfact : arg->f - 1.0; | 	f = arg->f < 1.0 ? arg->f + selmon->mfact : arg->f - 1.0; | ||||||
| 	if(f < 0.1 || f > 0.9) | 	if(f < 0.1 || f > 0.9) | ||||||
| @@ -1433,8 +1433,6 @@ setup(void) { | |||||||
| 	sw = DisplayWidth(dpy, screen); | 	sw = DisplayWidth(dpy, screen); | ||||||
| 	sh = DisplayHeight(dpy, screen); | 	sh = DisplayHeight(dpy, screen); | ||||||
| 	bh = dc.h = dc.font.height + 2; | 	bh = dc.h = dc.font.height + 2; | ||||||
| 	lt[0] = &layouts[0]; |  | ||||||
| 	lt[1] = &layouts[1 % LENGTH(layouts)]; |  | ||||||
| 	updategeom(); | 	updategeom(); | ||||||
| 	/* init atoms */ | 	/* init atoms */ | ||||||
| 	wmatom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False); | 	wmatom[WMProtocols] = XInternAtom(dpy, "WM_PROTOCOLS", False); | ||||||
| @@ -1484,7 +1482,7 @@ showhide(Client *c) { | |||||||
| 		return; | 		return; | ||||||
| 	if(ISVISIBLE(c)) { /* show clients top down */ | 	if(ISVISIBLE(c)) { /* show clients top down */ | ||||||
| 		XMoveWindow(dpy, c->win, c->x, c->y); | 		XMoveWindow(dpy, c->win, c->x, c->y); | ||||||
| 		if(!lt[c->mon->sellt]->arrange || c->isfloating) | 		if(!c->mon->lt[c->mon->sellt]->arrange || c->isfloating) | ||||||
| 			resize(c, c->x, c->y, c->w, c->h, False); | 			resize(c, c->x, c->y, c->w, c->h, False); | ||||||
| 		showhide(c->snext); | 		showhide(c->snext); | ||||||
| 	} | 	} | ||||||
| @@ -1730,6 +1728,8 @@ updategeom(void) { | |||||||
| 		m->mfact = mfact; | 		m->mfact = mfact; | ||||||
| 		m->showbar = SHOWBAR; | 		m->showbar = SHOWBAR; | ||||||
| 		m->topbar = TOPBAR; | 		m->topbar = TOPBAR; | ||||||
|  | 		m->lt[0] = &layouts[0]; | ||||||
|  | 		m->lt[1] = &layouts[1 % LENGTH(layouts)]; | ||||||
| 		updatebarpos(m); | 		updatebarpos(m); | ||||||
| 	} | 	} | ||||||
| 	/* reassign left over clients of disappeared monitors */ | 	/* reassign left over clients of disappeared monitors */ | ||||||
| @@ -1916,8 +1916,8 @@ void | |||||||
| zoom(const Arg *arg) { | zoom(const Arg *arg) { | ||||||
| 	Client *c = selmon->sel; | 	Client *c = selmon->sel; | ||||||
|  |  | ||||||
| 	if(!lt[selmon->sellt]->arrange | 	if(!selmon->lt[selmon->sellt]->arrange | ||||||
| 	|| lt[selmon->sellt]->arrange == monocle | 	|| selmon->lt[selmon->sellt]->arrange == monocle | ||||||
| 	|| (selmon->sel && selmon->sel->isfloating)) | 	|| (selmon->sel && selmon->sel->isfloating)) | ||||||
| 		return; | 		return; | ||||||
| 	if(c == nexttiled(selmon->clients)) | 	if(c == nexttiled(selmon->clients)) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Anselm R Garbe
					Anselm R Garbe