Simplify GetTouchEvents
With only one callee left, we are free to assume that !(flags & TOUCH_CLIENT_ID) Signed-off-by: Thomas Jaeger <ThJaeger@gmail.com> Reviewed-by: Peter Hutterer <peter.hutterer@who-t.net> Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
This commit is contained in:
		
							parent
							
								
									fe59774c55
								
							
						
					
					
						commit
						d0fd592fc7
					
				|  | @ -1833,10 +1833,7 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid, | ||||||
|     int i; |     int i; | ||||||
|     int num_events = 0; |     int num_events = 0; | ||||||
|     RawDeviceEvent *raw; |     RawDeviceEvent *raw; | ||||||
|     union touch { |  | ||||||
|         TouchPointInfoPtr dix_ti; |  | ||||||
|     DDXTouchPointInfoPtr ti; |     DDXTouchPointInfoPtr ti; | ||||||
|     } touchpoint; |  | ||||||
|     int need_rawevent = TRUE; |     int need_rawevent = TRUE; | ||||||
|     Bool emulate_pointer = FALSE; |     Bool emulate_pointer = FALSE; | ||||||
|     int client_id = 0; |     int client_id = 0; | ||||||
|  | @ -1855,37 +1852,15 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid, | ||||||
| 
 | 
 | ||||||
|     /* Find and/or create the DDX touch info */ |     /* Find and/or create the DDX touch info */ | ||||||
| 
 | 
 | ||||||
|     if (flags & TOUCH_CLIENT_ID) {      /* A DIX-submitted TouchEnd */ |     ti = TouchFindByDDXID(dev, ddx_touchid, (type == XI_TouchBegin)); | ||||||
|         touchpoint.dix_ti = TouchFindByClientID(dev, ddx_touchid); |     if (!ti) { | ||||||
|         BUG_RETURN_VAL(!touchpoint.dix_ti, 0); |  | ||||||
| 
 |  | ||||||
|         if (!mask_in || |  | ||||||
|             !valuator_mask_isset(mask_in, 0) || |  | ||||||
|             !valuator_mask_isset(mask_in, 1)) { |  | ||||||
|             ErrorF |  | ||||||
|                 ("[dix] dix-submitted events must have x/y valuator information.\n"); |  | ||||||
|             return 0; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         need_rawevent = FALSE; |  | ||||||
|         client_id = touchpoint.dix_ti->client_id; |  | ||||||
|     } |  | ||||||
|     else {                      /* a DDX-submitted touch */ |  | ||||||
| 
 |  | ||||||
|         touchpoint.ti = |  | ||||||
|             TouchFindByDDXID(dev, ddx_touchid, (type == XI_TouchBegin)); |  | ||||||
|         if (!touchpoint.ti) { |  | ||||||
|         ErrorFSigSafe("[dix] %s: unable to %s touch point %u\n", dev->name, |         ErrorFSigSafe("[dix] %s: unable to %s touch point %u\n", dev->name, | ||||||
|                       type == XI_TouchBegin ? "begin" : "find", ddx_touchid); |                       type == XI_TouchBegin ? "begin" : "find", ddx_touchid); | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|         client_id = touchpoint.ti->client_id; |     client_id = ti->client_id; | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     if (!(flags & TOUCH_CLIENT_ID)) |     emulate_pointer = ti->emulate_pointer; | ||||||
|         emulate_pointer = touchpoint.ti->emulate_pointer; |  | ||||||
|     else |  | ||||||
|         emulate_pointer = ! !(flags & TOUCH_POINTER_EMULATED); |  | ||||||
| 
 | 
 | ||||||
|     if (!IsMaster(dev)) |     if (!IsMaster(dev)) | ||||||
|         events = |         events = | ||||||
|  | @ -1905,11 +1880,6 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid, | ||||||
|     num_events++; |     num_events++; | ||||||
| 
 | 
 | ||||||
|     init_device_event(event, dev, ms); |     init_device_event(event, dev, ms); | ||||||
|     /* if submitted for master device, get the sourceid from there */ |  | ||||||
|     if (flags & TOUCH_CLIENT_ID) { |  | ||||||
|         event->sourceid = touchpoint.dix_ti->sourceid; |  | ||||||
|         /* TOUCH_CLIENT_ID implies norawevent */ |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     switch (type) { |     switch (type) { | ||||||
|     case XI_TouchBegin: |     case XI_TouchBegin: | ||||||
|  | @ -1934,20 +1904,20 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid, | ||||||
|         event->type = ET_TouchEnd; |         event->type = ET_TouchEnd; | ||||||
|         /* We can end the DDX touch here, since we don't use the active
 |         /* We can end the DDX touch here, since we don't use the active
 | ||||||
|          * field below */ |          * field below */ | ||||||
|         if (!(flags & TOUCH_CLIENT_ID)) |         TouchEndDDXTouch(dev, ti); | ||||||
|             TouchEndDDXTouch(dev, touchpoint.ti); |  | ||||||
|         break; |         break; | ||||||
|     default: |     default: | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|     if (t->mode == XIDirectTouch && !(flags & TOUCH_CLIENT_ID)) { | 
 | ||||||
|  |     if (t->mode == XIDirectTouch) { | ||||||
|         if (!valuator_mask_isset(&mask, 0)) |         if (!valuator_mask_isset(&mask, 0)) | ||||||
|             valuator_mask_set_double(&mask, 0, |             valuator_mask_set_double(&mask, 0, | ||||||
|                                      valuator_mask_get_double(touchpoint.ti-> |                                      valuator_mask_get_double(ti-> | ||||||
|                                                               valuators, 0)); |                                                               valuators, 0)); | ||||||
|         if (!valuator_mask_isset(&mask, 1)) |         if (!valuator_mask_isset(&mask, 1)) | ||||||
|             valuator_mask_set_double(&mask, 1, |             valuator_mask_set_double(&mask, 1, | ||||||
|                                      valuator_mask_get_double(touchpoint.ti-> |                                      valuator_mask_get_double(ti-> | ||||||
|                                                               valuators, 1)); |                                                               valuators, 1)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -1957,13 +1927,11 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid, | ||||||
|     if (t->mode == XIDirectTouch) { |     if (t->mode == XIDirectTouch) { | ||||||
|         transformAbsolute(dev, &mask); |         transformAbsolute(dev, &mask); | ||||||
| 
 | 
 | ||||||
|         if (!(flags & TOUCH_CLIENT_ID)) { |  | ||||||
|         for (i = 0; i < valuator_mask_size(&mask); i++) { |         for (i = 0; i < valuator_mask_size(&mask); i++) { | ||||||
|             double val; |             double val; | ||||||
| 
 | 
 | ||||||
|             if (valuator_mask_fetch_double(&mask, i, &val)) |             if (valuator_mask_fetch_double(&mask, i, &val)) | ||||||
|                     valuator_mask_set_double(touchpoint.ti->valuators, i, val); |                 valuator_mask_set_double(ti->valuators, i, val); | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         clipAbsolute(dev, &mask); |         clipAbsolute(dev, &mask); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue