diff options
| author | Ethan Furman <ethan@stoneleaf.us> | 2013-08-31 19:17:41 -0700 | 
|---|---|---|
| committer | Ethan Furman <ethan@stoneleaf.us> | 2013-08-31 19:17:41 -0700 | 
| commit | ec15a826ce6a49e4b1ba184517da9b739cb3db8f (patch) | |
| tree | 4d8ecd5aa3cd2cefa65b07f35a1ac4881c7353f2 /Lib/enum.py | |
| parent | 34567ec94b17e159fac8424559698f48a713991f (diff) | |
| download | cpython-git-ec15a826ce6a49e4b1ba184517da9b739cb3db8f.tar.gz | |
Close #18738:  Route __format__ calls to mixed-in type for mixed Enums (such as IntEnum).
Diffstat (limited to 'Lib/enum.py')
| -rw-r--r-- | Lib/enum.py | 18 | 
1 files changed, 16 insertions, 2 deletions
| diff --git a/Lib/enum.py b/Lib/enum.py index 5722b5f7eb..8219005bb6 100644 --- a/Lib/enum.py +++ b/Lib/enum.py @@ -50,7 +50,6 @@ def _make_class_unpicklable(cls):      cls.__reduce__ = _break_on_call_reduce      cls.__module__ = '<unknown>' -  class _EnumDict(dict):      """Keeps track of definition order of the enum items. @@ -182,7 +181,7 @@ class EnumMeta(type):          # double check that repr and friends are not the mixin's or various          # things break (such as pickle) -        for name in ('__repr__', '__str__', '__getnewargs__'): +        for name in ('__repr__', '__str__', '__format__', '__getnewargs__'):              class_method = getattr(enum_class, name)              obj_method = getattr(member_type, name, None)              enum_method = getattr(first_enum, name, None) @@ -441,6 +440,21 @@ class Enum(metaclass=EnumMeta):              return self is other          return NotImplemented +    def __format__(self, format_spec): +        # mixed-in Enums should use the mixed-in type's __format__, otherwise +        # we can get strange results with the Enum name showing up instead of +        # the value + +        # pure Enum branch +        if self._member_type_ is object: +            cls = str +            val = str(self) +        # mix-in branch +        else: +            cls = self._member_type_ +            val = self.value +        return cls.__format__(val, format_spec) +      def __getnewargs__(self):          return (self._value_, ) | 
