Applies the movestack patch
This commit is contained in:
		
							parent
							
								
									cb3f58ad06
								
							
						
					
					
						commit
						f9104b0615
					
				
					 2 changed files with 52 additions and 0 deletions
				
			
		|  | @ -59,6 +59,7 @@ static char dmenumon[2] = "0"; /* component of dmenucmd, manipulated in spawn() | |||
| static const char *dmenucmd[] = { "dmenu_run", "-m", dmenumon, "-fn", dmenufont, "-nb", col_gray1, "-nf", col_gray3, "-sb", col_cyan, "-sf", col_gray4, NULL }; | ||||
| static const char *termcmd[]  = { "st", NULL }; | ||||
| 
 | ||||
| #include "movestack.c" | ||||
| static Key keys[] = { | ||||
| 	/* modifier                     key        function        argument */ | ||||
| 	{ MODKEY,                       XK_p,      spawn,          {.v = dmenucmd } }, | ||||
|  | @ -66,6 +67,8 @@ static Key keys[] = { | |||
| 	{ MODKEY,                       XK_b,      togglebar,      {0} }, | ||||
| 	{ MODKEY,                       XK_j,      focusstack,     {.i = +1 } }, | ||||
| 	{ MODKEY,                       XK_k,      focusstack,     {.i = -1 } }, | ||||
| 	{ MODKEY|ShiftMask,             XK_j,      movestack,      {.i = +1 } }, | ||||
| 	{ MODKEY|ShiftMask,             XK_k,      movestack,      {.i = -1 } }, | ||||
| 	{ MODKEY,                       XK_i,      incnmaster,     {.i = +1 } }, | ||||
| 	{ MODKEY,                       XK_d,      incnmaster,     {.i = -1 } }, | ||||
| 	{ MODKEY,                       XK_h,      setmfact,       {.f = -0.05} }, | ||||
|  |  | |||
							
								
								
									
										49
									
								
								movestack.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								movestack.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,49 @@ | |||
| void | ||||
| movestack(const Arg *arg) { | ||||
| 	Client *c = NULL, *p = NULL, *pc = NULL, *i; | ||||
| 
 | ||||
| 	if(arg->i > 0) { | ||||
| 		/* find the client after selmon->sel */ | ||||
| 		for(c = selmon->sel->next; c && (!ISVISIBLE(c) || c->isfloating); c = c->next); | ||||
| 		if(!c) | ||||
| 			for(c = selmon->clients; c && (!ISVISIBLE(c) || c->isfloating); c = c->next); | ||||
| 
 | ||||
| 	} | ||||
| 	else { | ||||
| 		/* find the client before selmon->sel */ | ||||
| 		for(i = selmon->clients; i != selmon->sel; i = i->next) | ||||
| 			if(ISVISIBLE(i) && !i->isfloating) | ||||
| 				c = i; | ||||
| 		if(!c) | ||||
| 			for(; i; i = i->next) | ||||
| 				if(ISVISIBLE(i) && !i->isfloating) | ||||
| 					c = i; | ||||
| 	} | ||||
| 	/* find the client before selmon->sel and c */ | ||||
| 	for(i = selmon->clients; i && (!p || !pc); i = i->next) { | ||||
| 		if(i->next == selmon->sel) | ||||
| 			p = i; | ||||
| 		if(i->next == c) | ||||
| 			pc = i; | ||||
| 	} | ||||
| 
 | ||||
| 	/* swap c and selmon->sel selmon->clients in the selmon->clients list */ | ||||
| 	if(c && c != selmon->sel) { | ||||
| 		Client *temp = selmon->sel->next==c?selmon->sel:selmon->sel->next; | ||||
| 		selmon->sel->next = c->next==selmon->sel?c:c->next; | ||||
| 		c->next = temp; | ||||
| 
 | ||||
| 		if(p && p != c) | ||||
| 			p->next = c; | ||||
| 		if(pc && pc != selmon->sel) | ||||
| 			pc->next = selmon->sel; | ||||
| 
 | ||||
| 		if(selmon->sel == selmon->clients) | ||||
| 			selmon->clients = c; | ||||
| 		else if(c == selmon->clients) | ||||
| 			selmon->clients = selmon->sel; | ||||
| 
 | ||||
| 		arrange(selmon); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue