dix: simplify extension query
Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									be5a20d580
								
							
						
					
					
						commit
						9149af91d2
					
				|  | @ -142,19 +142,6 @@ AddExtension(const char *name, int NumEvents, int NumErrors, | ||||||
|     return ext; |     return ext; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int |  | ||||||
| FindExtension(const char *extname, int len) |  | ||||||
| { |  | ||||||
|     int i; |  | ||||||
| 
 |  | ||||||
|     for (i = 0; i < NumExtensions; i++) { |  | ||||||
|         if ((strlen(extensions[i]->name) == len) && |  | ||||||
|             !strncmp(extname, extensions[i]->name, len)) |  | ||||||
|             break; |  | ||||||
|     } |  | ||||||
|     return ((i == NumExtensions) ? -1 : i); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /*
 | /*
 | ||||||
|  * CheckExtension returns the extensions[] entry for the requested |  * CheckExtension returns the extensions[] entry for the requested | ||||||
|  * extension name.  Maybe this could just return a Bool instead? |  * extension name.  Maybe this could just return a Bool instead? | ||||||
|  | @ -162,13 +149,13 @@ FindExtension(const char *extname, int len) | ||||||
| ExtensionEntry * | ExtensionEntry * | ||||||
| CheckExtension(const char *extname) | CheckExtension(const char *extname) | ||||||
| { | { | ||||||
|     int n; |     for (int i = 0; i < NumExtensions; i++) { | ||||||
| 
 |         if (extensions[i] && | ||||||
|     n = FindExtension(extname, strlen(extname)); |             extensions[i]->name && | ||||||
|     if (n != -1) |             strcmp(extensions[i]->name, extname) == 0) | ||||||
|         return extensions[n]; |             return extensions[i]; | ||||||
|     else |     } | ||||||
|         return NULL; |     return NULL; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  | @ -237,14 +224,17 @@ ProcQueryExtension(ClientPtr client) | ||||||
|     if (!NumExtensions || !extensions) |     if (!NumExtensions || !extensions) | ||||||
|         rep.present = xFalse; |         rep.present = xFalse; | ||||||
|     else { |     else { | ||||||
|         int i = FindExtension((char *) &stuff[1], stuff->nbytes); |         char extname[PATH_MAX] = { 0 }; | ||||||
|         if (i < 0 || !ExtensionAvailable(client, extensions[i])) |         strncpy(extname, (char *) &stuff[1], min(stuff->nbytes, sizeof(extname)-1)); | ||||||
|  |         ExtensionEntry *extEntry = CheckExtension(extname); | ||||||
|  | 
 | ||||||
|  |         if (!extEntry || !ExtensionAvailable(client, extEntry)) | ||||||
|             rep.present = xFalse; |             rep.present = xFalse; | ||||||
|         else { |         else { | ||||||
|             rep.present = xTrue; |             rep.present = xTrue; | ||||||
|             rep.major_opcode = extensions[i]->base; |             rep.major_opcode = extEntry->base; | ||||||
|             rep.first_event = extensions[i]->eventBase; |             rep.first_event = extEntry->eventBase; | ||||||
|             rep.first_error = extensions[i]->errorBase; |             rep.first_error = extEntry->errorBase; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue