(!1893) dix: write out X_SetModifierMapping reply directly
No need for using a complex callback machinery, if we just move the little pieces of byte-swapping directly into the request handler. Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									231a38e6ba
								
							
						
					
					
						commit
						35d97a229b
					
				|  | @ -1759,7 +1759,6 @@ BadDeviceMap(BYTE * buff, int length, unsigned low, unsigned high, XID *errval) | |||
| int | ||||
| ProcSetModifierMapping(ClientPtr client) | ||||
| { | ||||
|     xSetModifierMappingReply rep; | ||||
|     int rc; | ||||
| 
 | ||||
|     REQUEST(xSetModifierMappingReq); | ||||
|  | @ -1769,11 +1768,6 @@ ProcSetModifierMapping(ClientPtr client) | |||
|                             bytes_to_int32(sizeof(xSetModifierMappingReq)))) | ||||
|         return BadLength; | ||||
| 
 | ||||
|     rep = (xSetModifierMappingReply) { | ||||
|         .type = X_Reply, | ||||
|         .sequenceNumber = client->sequence, | ||||
|         .length = 0 | ||||
|     }; | ||||
| 
 | ||||
|     rc = change_modmap(client, PickKeyboard(client), (KeyCode *) &stuff[1], | ||||
|                        stuff->numKeyPerModifier); | ||||
|  | @ -1782,9 +1776,17 @@ ProcSetModifierMapping(ClientPtr client) | |||
|     if (rc != MappingSuccess && rc != MappingFailed && rc != MappingBusy) | ||||
|         return rc; | ||||
| 
 | ||||
|     rep.success = rc; | ||||
|     xSetModifierMappingReply rep = { | ||||
|         .type = X_Reply, | ||||
|         .sequenceNumber = client->sequence, | ||||
|         .length = 0, | ||||
|         .success = rc, | ||||
|     }; | ||||
| 
 | ||||
|     WriteReplyToClient(client, sizeof(xSetModifierMappingReply), &rep); | ||||
|     if (client->swapped) { | ||||
|         swaps(&rep.sequenceNumber); | ||||
|     } | ||||
|     WriteToClient(client, sizeof(rep), &rep); | ||||
|     return Success; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -833,7 +833,7 @@ ReplySwapPtr ReplySwapVector[256] = { | |||
|     ReplyNotSwappd,                             /* 115 */ | ||||
|     (ReplySwapPtr) SGenericReply,               /* SetPointerMapping */ | ||||
|     (ReplySwapPtr) SGetPointerMappingReply, | ||||
|     (ReplySwapPtr) SGenericReply,               /* SetModifierMapping */ | ||||
|     ReplyNotSwappd, | ||||
|     (ReplySwapPtr) SGetModifierMappingReply,    /* 119 */ | ||||
|     ReplyNotSwappd,                             /* 120 */ | ||||
|     ReplyNotSwappd,                             /* 121 */ | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue