dix: clean up DeliverDeviceEvents.
Move mask checking into external function and streamline the code. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
This commit is contained in:
		
							parent
							
								
									6b6b660c36
								
							
						
					
					
						commit
						891cfc8020
					
				
							
								
								
									
										127
									
								
								dix/events.c
								
								
								
								
							
							
						
						
									
										127
									
								
								dix/events.c
								
								
								
								
							|  | @ -2142,6 +2142,66 @@ FixUpEventFromWindow( | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * Return masks for EventIsDeliverable. | ||||||
|  |  * @defgroup EventIsDeliverable return flags | ||||||
|  |  * @{ | ||||||
|  |  */ | ||||||
|  | #define XI_MASK                 (1 << 0) /**< XI mask set on window */ | ||||||
|  | #define CORE_MASK               (1 << 1) /**< Core mask set on window */ | ||||||
|  | #define DONT_PROPAGATE_MASK     (1 << 2) /**< DontPropagate mask set on window */ | ||||||
|  | /* @} */ | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Check if a given event is deliverable at all on a given window. | ||||||
|  |  * | ||||||
|  |  * This function only checks if any client wants it, not for a specific | ||||||
|  |  * client. | ||||||
|  |  * | ||||||
|  |  * @param[in] dev The device this event is being sent for. | ||||||
|  |  * @param[in] event The event that is to be sent. | ||||||
|  |  * @param[in] win The current event window. | ||||||
|  |  * @param[out] filter_out The event filter for this event. | ||||||
|  |  * | ||||||
|  |  * @return Bitmask of ::XI_MASK, ::CORE_MASK, and ::DONT_PROPAGATE_MASK. | ||||||
|  |  */ | ||||||
|  | static int | ||||||
|  | EventIsDeliverable(DeviceIntPtr dev, InternalEvent* event, WindowPtr win, | ||||||
|  |                    Mask *filter_out) | ||||||
|  | { | ||||||
|  |     int rc = 0; | ||||||
|  |     int filter = 0; | ||||||
|  |     int type; | ||||||
|  |     OtherInputMasks *inputMasks; | ||||||
|  | 
 | ||||||
|  |     type = GetXIType(event); | ||||||
|  |     filter = filters[dev->id][type]; | ||||||
|  | 
 | ||||||
|  |     /* Check for XI mask */ | ||||||
|  |     if (type && (inputMasks = wOtherInputMasks(win)) && | ||||||
|  |         (inputMasks->deliverableEvents[dev->id] & filter) && | ||||||
|  |         (inputMasks->inputEvents[dev->id] & filter)) | ||||||
|  |         rc |= XI_MASK; | ||||||
|  | 
 | ||||||
|  |     /* Check for XI DontPropagate mask */ | ||||||
|  |     if (type && inputMasks && | ||||||
|  |         (inputMasks->dontPropagateMask[dev->id] & filter)) | ||||||
|  |         rc |= DONT_PROPAGATE_MASK; | ||||||
|  | 
 | ||||||
|  |     /* Check for core mask */ | ||||||
|  |     type = GetCoreType(event); | ||||||
|  |     if (type && (win->deliverableEvents & filter) && | ||||||
|  |         ((wOtherEventMasks(win) | win->eventMask) & filter)) | ||||||
|  |         rc |= CORE_MASK; | ||||||
|  | 
 | ||||||
|  |     /* Check for core DontPropagate mask */ | ||||||
|  |     if (type && (filter & wDontPropagateMask(win))) | ||||||
|  |         rc |= DONT_PROPAGATE_MASK; | ||||||
|  | 
 | ||||||
|  |     *filter_out = filter; | ||||||
|  |     return rc; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Deliver events caused by input devices. |  * Deliver events caused by input devices. | ||||||
|  * |  * | ||||||
|  | @ -2166,14 +2226,11 @@ DeliverDeviceEvents(WindowPtr pWin, InternalEvent *event, GrabPtr grab, | ||||||
|                     WindowPtr stopAt, DeviceIntPtr dev) |                     WindowPtr stopAt, DeviceIntPtr dev) | ||||||
| { | { | ||||||
|     Window child = None; |     Window child = None; | ||||||
|     int type; |  | ||||||
|     Mask filter; |     Mask filter; | ||||||
|     int deliveries = 0; |     int deliveries = 0; | ||||||
|     OtherInputMasks *inputMasks; |  | ||||||
|     int mskidx = dev->id; |  | ||||||
|     xEvent core; |     xEvent core; | ||||||
|     xEvent *xE = NULL; |     xEvent *xE = NULL; | ||||||
|     int rc, count = 0; |     int rc, mask, count = 0; | ||||||
| 
 | 
 | ||||||
|     CHECKEVENT(event); |     CHECKEVENT(event); | ||||||
| 
 | 
 | ||||||
|  | @ -2194,59 +2251,41 @@ DeliverDeviceEvents(WindowPtr pWin, InternalEvent *event, GrabPtr grab, | ||||||
|     if (XaceHook(XACE_SEND_ACCESS, NULL, dev, pWin, xE, count)) |     if (XaceHook(XACE_SEND_ACCESS, NULL, dev, pWin, xE, count)) | ||||||
| 	goto unwind; | 	goto unwind; | ||||||
| 
 | 
 | ||||||
|     type = xE->u.u.type; |     while (pWin) | ||||||
|     filter = filters[dev->id][type]; |  | ||||||
| 
 |  | ||||||
|     while (pWin && type != GenericEvent) |  | ||||||
|     { |     { | ||||||
|         /* First try XI event delivery */ |         if ((mask = EventIsDeliverable(dev, event, pWin, &filter))) | ||||||
|         inputMasks = wOtherInputMasks(pWin); |  | ||||||
|         if (inputMasks && (filter & inputMasks->deliverableEvents[mskidx])) |  | ||||||
|         { |         { | ||||||
| 
 |             /* XI events first */ | ||||||
|             if (inputMasks && (inputMasks->inputEvents[mskidx] & filter)) |             if (mask & XI_MASK) | ||||||
|             { |             { | ||||||
|                 FixUpEventFromWindow(dev, xE, pWin, child, FALSE); |                 FixUpEventFromWindow(dev, xE, pWin, child, FALSE); | ||||||
|                 deliveries = DeliverEventsToWindow(dev, pWin, xE, count, |                 deliveries = DeliverEventsToWindow(dev, pWin, xE, count, | ||||||
|                                                    filter, grab, mskidx); |                                                    filter, grab, dev->id); | ||||||
|                 if (deliveries > 0) |                 if (deliveries > 0) | ||||||
|                     goto unwind; |                     goto unwind; | ||||||
|             } |             } | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         if ((deliveries < 0) || (pWin == stopAt) || |             /* Core event */ | ||||||
|             (inputMasks && (filter & inputMasks->dontPropagateMask[mskidx]))) |             if ((mask & CORE_MASK) && dev->isMaster && dev->coreEvents) | ||||||
|         { |  | ||||||
|             deliveries = 0; |  | ||||||
|             goto unwind; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (dev->isMaster && dev->coreEvents) |  | ||||||
|         { |  | ||||||
|             /* no XI event delivered. Try core event */ |  | ||||||
|             rc = EventToCore(event, &core); |  | ||||||
|             if (rc != Success) |  | ||||||
|             { |             { | ||||||
|                 if (rc != BadMatch) |                 rc = EventToCore(event, &core); | ||||||
|                     ErrorF("[dix] %s: Core conversion failed in DDE (%d, %d).\n", |                 if (rc != Success) | ||||||
|                             dev->name, event->u.any.type, rc); |  | ||||||
|                 goto unwind; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if (filter & pWin->deliverableEvents) |  | ||||||
|             { |  | ||||||
|                 if ((wOtherEventMasks(pWin)|pWin->eventMask) & filter) |  | ||||||
|                 { |                 { | ||||||
|                     FixUpEventFromWindow(dev, &core, pWin, child, FALSE); |                     if (rc != BadMatch) | ||||||
|                     deliveries = DeliverEventsToWindow(dev, pWin, &core, 1, |                         ErrorF("[dix] %s: Core conversion failed in DDE (%d, %d).\n", | ||||||
|                             filter, grab, 0); |                                 dev->name, event->u.any.type, rc); | ||||||
|                     if (deliveries > 0) |                     goto unwind; | ||||||
|                         goto unwind; |  | ||||||
|                 } |                 } | ||||||
|  | 
 | ||||||
|  |                 FixUpEventFromWindow(dev, &core, pWin, child, FALSE); | ||||||
|  |                 deliveries = DeliverEventsToWindow(dev, pWin, &core, 1, | ||||||
|  |                                                    filter, grab, dev->id); | ||||||
|  |                 if (deliveries > 0) | ||||||
|  |                     goto unwind; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if ((deliveries < 0) || (pWin == stopAt) || |             if ((deliveries < 0) || (pWin == stopAt) || | ||||||
|                 (filter & wDontPropagateMask(pWin))) |                 (mask & DONT_PROPAGATE_MASK)) | ||||||
|             { |             { | ||||||
|                 deliveries = 0; |                 deliveries = 0; | ||||||
|                 goto unwind; |                 goto unwind; | ||||||
|  | @ -2262,6 +2301,10 @@ unwind: | ||||||
|     return deliveries; |     return deliveries; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #undef XI_MASK | ||||||
|  | #undef CORE_MASK | ||||||
|  | #undef DONT_PROPAGATE_MASK | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Deliver event to a window and it's immediate parent. Used for most window |  * Deliver event to a window and it's immediate parent. Used for most window | ||||||
|  * events (CreateNotify, ConfigureNotify, etc.). Not useful for events that |  * events (CreateNotify, ConfigureNotify, etc.). Not useful for events that | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue