(!1893) dix: write out X_GetPointerControl 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
							
								
									db8ca026ea
								
							
						
					
					
						commit
						0f99a3a878
					
				|  | @ -2473,7 +2473,6 @@ ProcGetMotionEvents(ClientPtr client) | ||||||
| { | { | ||||||
|     WindowPtr pWin; |     WindowPtr pWin; | ||||||
|     xTimecoord *coords = (xTimecoord *) NULL; |     xTimecoord *coords = (xTimecoord *) NULL; | ||||||
|     xGetMotionEventsReply rep; |  | ||||||
|     int i, count, xmin, xmax, ymin, ymax, rc; |     int i, count, xmin, xmax, ymin, ymax, rc; | ||||||
|     unsigned long nEvents; |     unsigned long nEvents; | ||||||
|     DeviceIntPtr mouse = PickPointer(client); |     DeviceIntPtr mouse = PickPointer(client); | ||||||
|  | @ -2492,10 +2491,7 @@ ProcGetMotionEvents(ClientPtr client) | ||||||
|     UpdateCurrentTimeIf(); |     UpdateCurrentTimeIf(); | ||||||
|     if (mouse->valuator->motionHintWindow) |     if (mouse->valuator->motionHintWindow) | ||||||
|         MaybeStopHint(mouse, client); |         MaybeStopHint(mouse, client); | ||||||
|     rep = (xGetMotionEventsReply) { | 
 | ||||||
|         .type = X_Reply, |  | ||||||
|         .sequenceNumber = client->sequence |  | ||||||
|     }; |  | ||||||
|     nEvents = 0; |     nEvents = 0; | ||||||
|     start = ClientTimeToServerTime(stuff->start); |     start = ClientTimeToServerTime(stuff->start); | ||||||
|     stop = ClientTimeToServerTime(stuff->stop); |     stop = ClientTimeToServerTime(stuff->stop); | ||||||
|  | @ -2522,9 +2518,20 @@ ProcGetMotionEvents(ClientPtr client) | ||||||
|                 nEvents++; |                 nEvents++; | ||||||
|             } |             } | ||||||
|     } |     } | ||||||
|     rep.length = nEvents * bytes_to_int32(sizeof(xTimecoord)); | 
 | ||||||
|     rep.nEvents = nEvents; |     xGetMotionEventsReply rep = { | ||||||
|     WriteReplyToClient(client, sizeof(xGetMotionEventsReply), &rep); |         .type = X_Reply, | ||||||
|  |         .sequenceNumber = client->sequence, | ||||||
|  |         .length = nEvents * bytes_to_int32(sizeof(xTimecoord)), | ||||||
|  |         .nEvents = nEvents, | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     if (client->swapped) { | ||||||
|  |         swaps(&rep.sequenceNumber); | ||||||
|  |         swapl(&rep.length); | ||||||
|  |         swapl(&rep.nEvents); | ||||||
|  |     } | ||||||
|  |     WriteToClient(client, sizeof(xGetMotionEventsReply), &rep); | ||||||
|     if (nEvents) { |     if (nEvents) { | ||||||
|         client->pSwapReplyFunc = (ReplySwapPtr) SwapTimeCoordWrite; |         client->pSwapReplyFunc = (ReplySwapPtr) SwapTimeCoordWrite; | ||||||
|         WriteSwappedDataToClient(client, nEvents * sizeof(xTimecoord), |         WriteSwappedDataToClient(client, nEvents * sizeof(xTimecoord), | ||||||
|  |  | ||||||
|  | @ -287,15 +287,6 @@ SwapTimeCoordWrite(ClientPtr pClient, int size, xTimecoord * pRep) | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void _X_COLD |  | ||||||
| SGetMotionEventsReply(ClientPtr pClient, int size, xGetMotionEventsReply * pRep) |  | ||||||
| { |  | ||||||
|     swaps(&pRep->sequenceNumber); |  | ||||||
|     swapl(&pRep->length); |  | ||||||
|     swapl(&pRep->nEvents); |  | ||||||
|     WriteToClient(pClient, size, pRep); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void _X_COLD | void _X_COLD | ||||||
| SGetInputFocusReply(ClientPtr pClient, int size, xGetInputFocusReply * pRep) | SGetInputFocusReply(ClientPtr pClient, int size, xGetInputFocusReply * pRep) | ||||||
| { | { | ||||||
|  |  | ||||||
|  | @ -754,7 +754,7 @@ ReplySwapPtr ReplySwapVector[256] = { | ||||||
|     ReplyNotSwappd, |     ReplyNotSwappd, | ||||||
|     ReplyNotSwappd, |     ReplyNotSwappd, | ||||||
|     (ReplySwapPtr) SQueryPointerReply, |     (ReplySwapPtr) SQueryPointerReply, | ||||||
|     (ReplySwapPtr) SGetMotionEventsReply, |     ReplyNotSwappd, | ||||||
|     ReplyNotSwappd,                             /* 40 */ |     ReplyNotSwappd,                             /* 40 */ | ||||||
|     ReplyNotSwappd, |     ReplyNotSwappd, | ||||||
|     ReplyNotSwappd, |     ReplyNotSwappd, | ||||||
|  |  | ||||||
|  | @ -75,11 +75,6 @@ extern void SwapTimeCoordWrite(ClientPtr /* pClient */ , | ||||||
|                                int /* size */ , |                                int /* size */ , | ||||||
|                                xTimecoord * /* pRep */ ); |                                xTimecoord * /* pRep */ ); | ||||||
| 
 | 
 | ||||||
| extern void SGetMotionEventsReply(ClientPtr /* pClient */ , |  | ||||||
|                                   int /* size */ , |  | ||||||
|                                   xGetMotionEventsReply *       /* pRep */ |  | ||||||
|     ); |  | ||||||
| 
 |  | ||||||
| extern void SGetInputFocusReply(ClientPtr /* pClient */ , | extern void SGetInputFocusReply(ClientPtr /* pClient */ , | ||||||
|                                 int /* size */ , |                                 int /* size */ , | ||||||
|                                 xGetInputFocusReply * /* pRep */ ); |                                 xGetInputFocusReply * /* pRep */ ); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue