(!1654) Xnest: screen move assigment between depths and visual assignment to own function
Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									da4e2c98fb
								
							
						
					
					
						commit
						cbd748e78d
					
				|  | @ -143,13 +143,38 @@ static miPointerSpriteFuncRec xnestPointerSpriteFuncs = { | ||||||
|     xnestDeviceCursorCleanup |     xnestDeviceCursorCleanup | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | static int add_depth_visual(DepthPtr depths, int numDepths, int nplanes, VisualID vid) | ||||||
|  | { | ||||||
|  |     DepthPtr walk = NULL; | ||||||
|  | 
 | ||||||
|  |     for (int j = 0; j < numDepths; j++) | ||||||
|  |         if (depths[j].depth == nplanes) { | ||||||
|  |             walk = &depths[j]; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     if (!walk) { | ||||||
|  |         walk = &depths[numDepths++]; | ||||||
|  |         walk->depth = nplanes; | ||||||
|  |         walk->numVids = 0; | ||||||
|  |         walk->vids = (VisualID *) malloc(MAXVISUALSPERDEPTH * sizeof(VisualID)); | ||||||
|  |     } | ||||||
|  |     if (walk->numVids >= MAXVISUALSPERDEPTH) { | ||||||
|  |         FatalError("Visual table overflow"); | ||||||
|  |     } | ||||||
|  |     walk->vids[walk->numVids] = vid; | ||||||
|  |     walk->numVids++; | ||||||
|  | 
 | ||||||
|  |     return numDepths; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| Bool | Bool | ||||||
| xnestOpenScreen(ScreenPtr pScreen, int argc, char *argv[]) | xnestOpenScreen(ScreenPtr pScreen, int argc, char *argv[]) | ||||||
| { | { | ||||||
|     VisualPtr visuals; |     VisualPtr visuals; | ||||||
|     DepthPtr depths; |     DepthPtr depths; | ||||||
|     int numVisuals, numDepths; |     int numVisuals, numDepths; | ||||||
|     int i, j, depthIndex; |     int i, j; | ||||||
|     unsigned long valuemask; |     unsigned long valuemask; | ||||||
|     VisualID defaultVisual; |     VisualID defaultVisual; | ||||||
|     int rootDepth; |     int rootDepth; | ||||||
|  | @ -218,27 +243,7 @@ xnestOpenScreen(ScreenPtr pScreen, int argc, char *argv[]) | ||||||
| 
 | 
 | ||||||
|         visuals[numVisuals].vid = FakeClientID(0); |         visuals[numVisuals].vid = FakeClientID(0); | ||||||
| 
 | 
 | ||||||
|         depthIndex = UNDEFINED; |         numDepths = add_depth_visual(depths, numDepths, visuals[numVisuals].nplanes, visuals[numVisuals].vid); | ||||||
|         for (j = 0; j < numDepths; j++) |  | ||||||
|             if (depths[j].depth == xnestVisuals[i].depth) { |  | ||||||
|                 depthIndex = j; |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|         if (depthIndex == UNDEFINED) { |  | ||||||
|             depthIndex = numDepths; |  | ||||||
|             depths[depthIndex].depth = xnestVisuals[i].depth; |  | ||||||
|             depths[depthIndex].numVids = 0; |  | ||||||
|             depths[depthIndex].vids = |  | ||||||
|                 (VisualID *) malloc(MAXVISUALSPERDEPTH * sizeof(VisualID)); |  | ||||||
|             numDepths++; |  | ||||||
|         } |  | ||||||
|         if (depths[depthIndex].numVids >= MAXVISUALSPERDEPTH) { |  | ||||||
|             FatalError("Visual table overflow"); |  | ||||||
|         } |  | ||||||
|         depths[depthIndex].vids[depths[depthIndex].numVids] = |  | ||||||
|             visuals[numVisuals].vid; |  | ||||||
|         depths[depthIndex].numVids++; |  | ||||||
| 
 | 
 | ||||||
|         if (xnestUserDefaultClass || xnestUserDefaultDepth) { |         if (xnestUserDefaultClass || xnestUserDefaultDepth) { | ||||||
|             if ((!xnestDefaultClass || visuals[numVisuals].class == xnestDefaultClass) && |             if ((!xnestDefaultClass || visuals[numVisuals].class == xnestDefaultClass) && | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue