mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-26 00:04:03 -04:00 
			
		
		
		
	Fix crash when trying to use meta enums on some platforms
Keeping references to static meta objects and meta enums around seems to avoid the crash
This commit is contained in:
		
							parent
							
								
									2c349b2512
								
							
						
					
					
						commit
						278ccb8e85
					
				| @ -17,6 +17,9 @@ | |||||||
| *************************************************************************** | *************************************************************************** | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
|  | META_OBJECT_BY_ENUM_CLASS = {} | ||||||
|  | META_ENUM_BY_ENUM_CLASS = {} | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| def metaEnumFromValue(enumValue, baseClass=None, raiseException=True): | def metaEnumFromValue(enumValue, baseClass=None, raiseException=True): | ||||||
|     """ |     """ | ||||||
| @ -39,6 +42,11 @@ def metaEnumFromType(enumClass, baseClass=None, raiseException=True): | |||||||
|     :param raiseException: if False, no exception will be raised and None will be return in case of failure |     :param raiseException: if False, no exception will be raised and None will be return in case of failure | ||||||
|     :return: the QMetaEnum if it succeeds, None otherwise |     :return: the QMetaEnum if it succeeds, None otherwise | ||||||
|     """ |     """ | ||||||
|  |     global META_OBJECT_BY_ENUM_CLASS | ||||||
|  |     global META_ENUM_BY_ENUM_CLASS | ||||||
|  |     if enumClass in META_ENUM_BY_ENUM_CLASS: | ||||||
|  |         return META_ENUM_BY_ENUM_CLASS[enumClass] | ||||||
|  | 
 | ||||||
|     if enumClass == int: |     if enumClass == int: | ||||||
|         if raiseException: |         if raiseException: | ||||||
|             raise TypeError("enumClass is an int, while it should be an enum") |             raise TypeError("enumClass is an int, while it should be an enum") | ||||||
| @ -54,8 +62,11 @@ def metaEnumFromType(enumClass, baseClass=None, raiseException=True): | |||||||
|                 raise ValueError("Enum type does not implement baseClass method. Provide the base class as argument.") |                 raise ValueError("Enum type does not implement baseClass method. Provide the base class as argument.") | ||||||
| 
 | 
 | ||||||
|     try: |     try: | ||||||
|         idx = baseClass.staticMetaObject.indexOfEnumerator(enumClass.__name__) |         meta_object = baseClass.staticMetaObject | ||||||
|         meta_enum = baseClass.staticMetaObject.enumerator(idx) |         META_OBJECT_BY_ENUM_CLASS[enumClass] = meta_object | ||||||
|  |         idx = meta_object.indexOfEnumerator(enumClass.__name__) | ||||||
|  |         meta_enum = meta_object.enumerator(idx) | ||||||
|  |         META_ENUM_BY_ENUM_CLASS[enumClass] = meta_enum | ||||||
|     except AttributeError: |     except AttributeError: | ||||||
|         if raiseException: |         if raiseException: | ||||||
|             raise TypeError("could not get the metaEnum for {}".format(enumClass.__name__)) |             raise TypeError("could not get the metaEnum for {}".format(enumClass.__name__)) | ||||||
|  | |||||||
| @ -27,10 +27,10 @@ class TestCoreAdditions(unittest.TestCase): | |||||||
|         self.assertIsNotNone(me) |         self.assertIsNotNone(me) | ||||||
|         self.assertEqual(me.valueToKey(QgsTolerance.Pixels), 'Pixels') |         self.assertEqual(me.valueToKey(QgsTolerance.Pixels), 'Pixels') | ||||||
| 
 | 
 | ||||||
|         # if using same variable twice (e.g. me = me2), this seg faults |         # check that using same variable twice doesn't segfault | ||||||
|         me2 = metaEnumFromValue(QgsTolerance.Pixels, QgsTolerance) |         me = metaEnumFromValue(QgsTolerance.Pixels, QgsTolerance) | ||||||
|         self.assertIsNotNone(me) |         self.assertIsNotNone(me) | ||||||
|         self.assertEqual(me2.valueToKey(QgsTolerance.Pixels), 'Pixels') |         self.assertEqual(me.valueToKey(QgsTolerance.Pixels), 'Pixels') | ||||||
| 
 | 
 | ||||||
|         # do not raise error |         # do not raise error | ||||||
|         self.assertIsNone(metaEnumFromValue(1, QgsTolerance, False)) |         self.assertIsNone(metaEnumFromValue(1, QgsTolerance, False)) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user