(!1601) Xext: xres: ProcXResQueryClientResources() simplify payload write out
Collect the few bits in a local array, so one WriteToClient() call is sufficient. That's also easing further simplifications in upcoming commits. Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									97ef16e966
								
							
						
					
					
						commit
						ed927df59c
					
				
							
								
								
									
										28
									
								
								Xext/xres.c
								
								
								
								
							
							
						
						
									
										28
									
								
								Xext/xres.c
								
								
								
								
							|  | @ -307,10 +307,14 @@ ProcXResQueryClientResources(ClientPtr client) | |||
| 
 | ||||
|     FindAllClientResources(clients[clientID], ResFindAllRes, counts); | ||||
| 
 | ||||
|     int cnt[lastResourceType + 1]; | ||||
| 
 | ||||
|     for (i = 0; i <= lastResourceType; i++) { | ||||
|         if (counts[i]) | ||||
|         if (counts[i]) { | ||||
|             cnt[num_types] = counts[i]; | ||||
|             num_types++; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     xXResQueryClientResourcesReply rep = { | ||||
|         .type = X_Reply, | ||||
|  | @ -324,26 +328,20 @@ ProcXResQueryClientResources(ClientPtr client) | |||
|         swapl(&rep.num_types); | ||||
|     } | ||||
| 
 | ||||
|     WriteToClient(client, sizeof(xXResQueryClientResourcesReply), &rep); | ||||
|     xXResType scratch[num_types]; | ||||
| 
 | ||||
|     if (num_types) { | ||||
|         xXResType scratch; | ||||
| 
 | ||||
|         for (i = 0; i < lastResourceType; i++) { | ||||
|             if (!counts[i]) | ||||
|                 continue; | ||||
| 
 | ||||
|             scratch.resource_type = resourceTypeAtom(i + 1); | ||||
|             scratch.count = counts[i]; | ||||
|     for (i = 0; i < num_types; i++) { | ||||
|         scratch[i].resource_type = resourceTypeAtom(i + 1); | ||||
|         scratch[i].count = cnt[i]; | ||||
| 
 | ||||
|         if (client->swapped) { | ||||
|                 swapl(&scratch.resource_type); | ||||
|                 swapl(&scratch.count); | ||||
|             } | ||||
|             WriteToClient(client, sz_xXResType, &scratch); | ||||
|             swapl(&scratch[i].resource_type); | ||||
|             swapl(&scratch[i].count); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     WriteToClient(client, sizeof(xXResQueryClientResourcesReply), &rep); | ||||
|     WriteToClient(client, sizeof(scratch), scratch); | ||||
|     return Success; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue