|  | @@ -1683,7 +1683,7 @@ updatebarpos(Monitor *m) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void
 | 
	
		
			
				|  |  |  updategeom(void) {
 | 
	
		
			
				|  |  | -	int i, n = 1;
 | 
	
		
			
				|  |  | +	int i, n = 1, nn;
 | 
	
		
			
				|  |  |  	Client *c;
 | 
	
		
			
				|  |  |  	Monitor *newmons = NULL, *m = NULL, *tm;
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -1692,6 +1692,11 @@ updategeom(void) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	if(XineramaIsActive(dpy))
 | 
	
		
			
				|  |  |  		info = XineramaQueryScreens(dpy, &n);
 | 
	
		
			
				|  |  | +	for(i = 1, nn = n; i < n; i++)
 | 
	
		
			
				|  |  | +		if(info[i - 1].x_org == info[i].x_org && info[i - 1].y_org == info[i].y_org
 | 
	
		
			
				|  |  | +		&& info[i - 1].width == info[i].width && info[i - 1].height == info[i].height)
 | 
	
		
			
				|  |  | +			--nn;
 | 
	
		
			
				|  |  | +	n = nn; /* we only consider unique geometrys as separate screens */
 | 
	
		
			
				|  |  |  #endif /* XINERAMA */
 | 
	
		
			
				|  |  |  	/* allocate monitor(s) for the new geometry setup */
 | 
	
		
			
				|  |  |  	for(i = 0; i < n; i++) {
 |