diff options
| author | Ethan Furman <ethan@stoneleaf.us> | 2013-09-25 07:14:41 -0700 | 
|---|---|---|
| committer | Ethan Furman <ethan@stoneleaf.us> | 2013-09-25 07:14:41 -0700 | 
| commit | e03ea37a7bea48c46e6d96851f471db0f3c8e6e2 (patch) | |
| tree | 7b3ac5ca8ed5b94a29a80400e24746788c0b9efb /Lib/enum.py | |
| parent | 7cba5fd267219d23aec97fad91d73bea77daf5e2 (diff) | |
| download | cpython-git-e03ea37a7bea48c46e6d96851f471db0f3c8e6e2.tar.gz | |
Close #19030: improvements to inspect and Enum.
inspect.getmembers and inspect.classify_class_attrs now search the metaclass
mro for types.DynamicClassAttributes (what use to be called
enum._RouteClassAttributeToGetattr); in part this means that these two
functions no longer rely solely on dir().
Besides now returning more accurate information, these improvements also
allow a more helpful help() on Enum classes.
Diffstat (limited to 'Lib/enum.py')
| -rw-r--r-- | Lib/enum.py | 32 | 
1 files changed, 3 insertions, 29 deletions
| diff --git a/Lib/enum.py b/Lib/enum.py index 0a7afc45c0..45bfbb4e29 100644 --- a/Lib/enum.py +++ b/Lib/enum.py @@ -1,36 +1,10 @@  import sys  from collections import OrderedDict -from types import MappingProxyType +from types import MappingProxyType, DynamicClassAttribute  __all__ = ['Enum', 'IntEnum', 'unique'] -class _RouteClassAttributeToGetattr: -    """Route attribute access on a class to __getattr__. - -    This is a descriptor, used to define attributes that act differently when -    accessed through an instance and through a class.  Instance access remains -    normal, but access to an attribute through a class will be routed to the -    class's __getattr__ method; this is done by raising AttributeError. - -    """ -    def __init__(self, fget=None): -        self.fget = fget -        if fget.__doc__ is not None: -            self.__doc__ = fget.__doc__ - -    def __get__(self, instance, ownerclass=None): -        if instance is None: -            raise AttributeError() -        return self.fget(instance) - -    def __set__(self, instance, value): -        raise AttributeError("can't set attribute") - -    def __delete__(self, instance): -        raise AttributeError("can't delete attribute") - -  def _is_descriptor(obj):      """Returns True if obj is a descriptor, False otherwise."""      return ( @@ -504,12 +478,12 @@ class Enum(metaclass=EnumMeta):      # members are not set directly on the enum class -- __getattr__ is      # used to look them up. -    @_RouteClassAttributeToGetattr +    @DynamicClassAttribute      def name(self):          """The name of the Enum member."""          return self._name_ -    @_RouteClassAttributeToGetattr +    @DynamicClassAttribute      def value(self):          """The value of the Enum member."""          return self._value_ | 
