Xi: fix up sloppy class copying causing segfaults.
This commit is contained in:
		
							parent
							
								
									53539688ca
								
							
						
					
					
						commit
						070195dbf8
					
				|  | @ -220,6 +220,7 @@ DeepCopyDeviceClasses(DeviceIntPtr from, DeviceIntPtr to) | ||||||
| #ifdef XKB | #ifdef XKB | ||||||
|         to->key->xkbInfo = NULL; |         to->key->xkbInfo = NULL; | ||||||
| #endif | #endif | ||||||
|  |         to->key->curKeySyms.map = NULL; | ||||||
|         CopyKeyClass(from, to); |         CopyKeyClass(from, to); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -233,8 +234,12 @@ DeepCopyDeviceClasses(DeviceIntPtr from, DeviceIntPtr to) | ||||||
|         if (!v) |         if (!v) | ||||||
|             FatalError("[Xi] no memory for class shift.\n"); |             FatalError("[Xi] no memory for class shift.\n"); | ||||||
|         memcpy(v, from->valuator, sizeof(ValuatorClassRec)); |         memcpy(v, from->valuator, sizeof(ValuatorClassRec)); | ||||||
|  |         v->motion = NULL; | ||||||
|  | 
 | ||||||
|         v->axes = (AxisInfoPtr)&v[1]; |         v->axes = (AxisInfoPtr)&v[1]; | ||||||
|         memcpy(v->axes, from->valuator->axes, v->numAxes * sizeof(AxisInfo)); |         memcpy(v->axes, from->valuator->axes, v->numAxes * sizeof(AxisInfo)); | ||||||
|  | 
 | ||||||
|  |         v->axisVal = (int*)(v->axes + from->valuator->numAxes); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ALLOC_COPY_CLASS_IF(button, ButtonClassRec); |     ALLOC_COPY_CLASS_IF(button, ButtonClassRec); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue