hdl.rec: fix using Enum subclass as shape if direction is specified.
Also improves error messages. Fixes #224.
This commit is contained in:
		
							parent
							
								
									4c582ef609
								
							
						
					
					
						commit
						1976310bf0
					
				|  | @ -35,8 +35,6 @@ class Layout: | ||||||
|             if len(field) == 2: |             if len(field) == 2: | ||||||
|                 name, shape = field |                 name, shape = field | ||||||
|                 direction = DIR_NONE |                 direction = DIR_NONE | ||||||
|                 if isinstance(shape, type) and issubclass(shape, Enum): |  | ||||||
|                     shape = _enum_shape(shape) |  | ||||||
|                 if isinstance(shape, list): |                 if isinstance(shape, list): | ||||||
|                     shape = Layout.wrap(shape) |                     shape = Layout.wrap(shape) | ||||||
|             else: |             else: | ||||||
|  | @ -48,9 +46,11 @@ class Layout: | ||||||
|             if not isinstance(name, str): |             if not isinstance(name, str): | ||||||
|                 raise TypeError("Field {!r} has invalid name: should be a string" |                 raise TypeError("Field {!r} has invalid name: should be a string" | ||||||
|                                 .format(field)) |                                 .format(field)) | ||||||
|  |             if isinstance(shape, type) and issubclass(shape, Enum): | ||||||
|  |                 shape = _enum_shape(shape) | ||||||
|             if not isinstance(shape, (int, tuple, Layout)): |             if not isinstance(shape, (int, tuple, Layout)): | ||||||
|                 raise TypeError("Field {!r} has invalid shape: should be an int, tuple, or list " |                 raise TypeError("Field {!r} has invalid shape: should be an int, tuple, Enum, or " | ||||||
|                                 "of fields of a nested record" |                                 "list of fields of a nested record" | ||||||
|                                 .format(field)) |                                 .format(field)) | ||||||
|             if name in self.fields: |             if name in self.fields: | ||||||
|                 raise NameError("Field {!r} has a name that is already present in the layout" |                 raise NameError("Field {!r} has a name that is already present in the layout" | ||||||
|  |  | ||||||
|  | @ -36,8 +36,10 @@ class LayoutTestCase(FHDLTestCase): | ||||||
|     def test_enum_field(self): |     def test_enum_field(self): | ||||||
|         layout = Layout.wrap([ |         layout = Layout.wrap([ | ||||||
|             ("enum", UnsignedEnum), |             ("enum", UnsignedEnum), | ||||||
|  |             ("enum_dir", UnsignedEnum, DIR_FANOUT), | ||||||
|         ]) |         ]) | ||||||
|         self.assertEqual(layout["enum"], ((2, False), DIR_NONE)) |         self.assertEqual(layout["enum"], ((2, False), DIR_NONE)) | ||||||
|  |         self.assertEqual(layout["enum_dir"], ((2, False), DIR_FANOUT)) | ||||||
| 
 | 
 | ||||||
|     def test_slice_tuple(self): |     def test_slice_tuple(self): | ||||||
|         layout = Layout.wrap([ |         layout = Layout.wrap([ | ||||||
|  | @ -75,7 +77,7 @@ class LayoutTestCase(FHDLTestCase): | ||||||
| 
 | 
 | ||||||
|     def test_wrong_shape(self): |     def test_wrong_shape(self): | ||||||
|         with self.assertRaises(TypeError, |         with self.assertRaises(TypeError, | ||||||
|                 msg="Field ('a', 'x') has invalid shape: should be an int, tuple, or " |                 msg="Field ('a', 'x') has invalid shape: should be an int, tuple, Enum, or " | ||||||
|                     "list of fields of a nested record"): |                     "list of fields of a nested record"): | ||||||
|             Layout.wrap([("a", "x")]) |             Layout.wrap([("a", "x")]) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 whitequark
						whitequark