diff --git a/amaranth/lib/enum.py b/amaranth/lib/enum.py index 10c3666..6dc70e7 100644 --- a/amaranth/lib/enum.py +++ b/amaranth/lib/enum.py @@ -118,7 +118,7 @@ class EnumMeta(ShapeCastable, py_enum.EnumMeta): # replacement for `enum.Enum`. return Shape._cast_plain_enum(cls) - def __call__(cls, value): + def __call__(cls, value, *args, **kwargs): # :class:`py_enum.Enum` uses ``__call__()`` for type casting: ``E(x)`` returns # the enumeration member whose value equals ``x``. In this case, ``x`` must be a concrete # value. @@ -130,7 +130,7 @@ class EnumMeta(ShapeCastable, py_enum.EnumMeta): # comparisons with enum members of the wrong type. if isinstance(value, Value): return value - return super().__call__(value) + return super().__call__(value, *args, **kwargs) def const(cls, init): # Same considerations apply as above. diff --git a/tests/test_lib_enum.py b/tests/test_lib_enum.py index 9d5a27e..5c86d60 100644 --- a/tests/test_lib_enum.py +++ b/tests/test_lib_enum.py @@ -116,3 +116,6 @@ class EnumTestCase(FHDLTestCase): r"shape used in bit vector context; define the enumeration by inheriting from " r"the class in amaranth\.lib\.enum and specifying the 'shape=' keyword argument$"): Cat(EnumA.A) + + def test_functional(self): + Enum("FOO", ["BAR", "BAZ"])