some cleanup handling for index based mon search
This commit is contained in:
		
							parent
							
								
									27db9d4448
								
							
						
					
					
						commit
						029655bb22
					
				
					 1 changed files with 18 additions and 19 deletions
				
			
		
							
								
								
									
										37
									
								
								dwm.c
									
										
									
									
									
								
							
							
						
						
									
										37
									
								
								dwm.c
									
										
									
									
									
								
							|  | @ -177,6 +177,7 @@ static void focusstack(const Arg *arg); | |||
| static Client *getclient(Window w); | ||||
| static unsigned long getcolor(const char *colstr); | ||||
| static Monitor *getmon(Window w); | ||||
| static Monitor *getmonn(unsigned int n); | ||||
| static Monitor *getmonxy(int x, int y); | ||||
| static Bool getrootpointer(int *x, int *y); | ||||
| static long getstate(Window w); | ||||
|  | @ -800,18 +801,13 @@ focusin(XEvent *e) { /* there are some broken focus acquiring clients */ | |||
| #ifdef XINERAMA | ||||
| void | ||||
| focusmon(const Arg *arg) { | ||||
| 	unsigned int i; | ||||
| 	Monitor *m;  | ||||
| 	Monitor *m; | ||||
| 
 | ||||
| 	for(i = 0, m = mons; m; m = m->next, i++) | ||||
| 		if(i == arg->ui) { | ||||
| 			if(m == selmon) | ||||
| 				return; | ||||
| 			unfocus(selmon->sel); | ||||
| 			selmon = m; | ||||
| 			focus(NULL); | ||||
| 			break; | ||||
| 		} | ||||
| 	if(!(m = getmonn(arg->ui)) || m == selmon) | ||||
| 		return; | ||||
| 	unfocus(selmon->sel); | ||||
| 	selmon = m; | ||||
| 	focus(NULL); | ||||
| } | ||||
| #endif /* XINERAMA */ | ||||
| 
 | ||||
|  | @ -879,6 +875,15 @@ getmon(Window w) { | |||
| 	return NULL; | ||||
| } | ||||
| 
 | ||||
| Monitor * | ||||
| getmonn(unsigned int n) { | ||||
| 	unsigned int i; | ||||
| 	Monitor *m; | ||||
| 
 | ||||
| 	for(m = mons, i = 0; m && i != n; m = m->next, i++); | ||||
| 	return m; | ||||
| } | ||||
| 
 | ||||
| Monitor * | ||||
| getmonxy(int x, int y) { | ||||
| 	Monitor *m; | ||||
|  | @ -1542,17 +1547,11 @@ tag(const Arg *arg) { | |||
| #ifdef XINERAMA | ||||
| void | ||||
| tagmon(const Arg *arg) { | ||||
| 	unsigned int i; | ||||
| 	Client *c; | ||||
| 	Monitor *m; | ||||
| 
 | ||||
| 	if(!(c = selmon->sel)) | ||||
| 	if(!selmon->sel || !(m = getmonn(arg->ui))) | ||||
| 		return; | ||||
| 	for(i = 0, m = mons; m; m = m->next, i++) | ||||
| 		if(i == arg->ui) { | ||||
| 			sendmon(c, m); | ||||
| 			break; | ||||
| 		} | ||||
| 	sendmon(selmon->sel, m); | ||||
| } | ||||
| #endif /* XINERAMA */ | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue