Compare commits
2 Commits
a1251980d2
...
f7dca9b9c8
Author | SHA1 | Date |
---|---|---|
Ethan Furman | f7dca9b9c8 | |
Miss Islington (bot) | 3bb85672bb |
|
@ -170,7 +170,7 @@ class EnumMeta(type):
|
|||
Metaclass for Enum
|
||||
"""
|
||||
@classmethod
|
||||
def __prepare__(metacls, cls, bases):
|
||||
def __prepare__(metacls, cls, bases, **kwds):
|
||||
# check that previous enum members do not exist
|
||||
metacls._check_for_existing_members(cls, bases)
|
||||
# create the namespace dict
|
||||
|
|
|
@ -2065,7 +2065,7 @@ class TestEnum(unittest.TestCase):
|
|||
except ValueError:
|
||||
pass
|
||||
|
||||
def test_init_subclass(self):
|
||||
def test_init_subclass_calling(self):
|
||||
class MyEnum(Enum):
|
||||
def __init_subclass__(cls, **kwds):
|
||||
super(MyEnum, cls).__init_subclass__(**kwds)
|
||||
|
@ -2101,6 +2101,16 @@ class TestEnum(unittest.TestCase):
|
|||
self.assertFalse(NeverEnum.__dict__.get('_test1', False))
|
||||
self.assertFalse(NeverEnum.__dict__.get('_test2', False))
|
||||
|
||||
def test_init_subclass_parameter(self):
|
||||
class multiEnum(Enum):
|
||||
def __init_subclass__(cls, multi):
|
||||
for member in cls:
|
||||
member._as_parameter_ = multi * member.value
|
||||
class E(multiEnum, multi=3):
|
||||
A = 1
|
||||
B = 2
|
||||
self.assertEqual(E.A._as_parameter_, 3)
|
||||
self.assertEqual(E.B._as_parameter_, 6)
|
||||
|
||||
class TestOrder(unittest.TestCase):
|
||||
|
||||
|
|
|
@ -0,0 +1,2 @@
|
|||
`EnumMeta.__prepare__` now accepts `**kwds` to properly support
|
||||
`__init_subclass__`
|
|
@ -0,0 +1,2 @@
|
|||
Fixed Python 3 compatibility issue with gdb/libpython.py handling of attribute
|
||||
dictionaries.
|
|
@ -468,7 +468,7 @@ class InstanceProxy(object):
|
|||
def __repr__(self):
|
||||
if isinstance(self.attrdict, dict):
|
||||
kwargs = ', '.join(["%s=%r" % (arg, val)
|
||||
for arg, val in self.attrdict.iteritems()])
|
||||
for arg, val in self.attrdict.items()])
|
||||
return '<%s(%s) at remote 0x%x>' % (self.cl_name,
|
||||
kwargs, self.address)
|
||||
else:
|
||||
|
|
Loading…
Reference in New Issue