123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- # coding: utf-8
- """Mixin for mapping set/getattr to self.set/get"""
- # Copyright (C) PyZMQ Developers
- # Distributed under the terms of the Modified BSD License.
- import errno
- from . import constants
- class AttributeSetter(object):
- def __setattr__(self, key, value):
- """set zmq options by attribute"""
- if key in self.__dict__:
- object.__setattr__(self, key, value)
- return
- # regular setattr only allowed for class-defined attributes
- for obj in self.__class__.mro():
- if key in obj.__dict__:
- object.__setattr__(self, key, value)
- return
- upper_key = key.upper()
- try:
- opt = getattr(constants, upper_key)
- except AttributeError:
- raise AttributeError("%s has no such option: %s" % (
- self.__class__.__name__, upper_key)
- )
- else:
- self._set_attr_opt(upper_key, opt, value)
- def _set_attr_opt(self, name, opt, value):
- """override if setattr should do something other than call self.set"""
- self.set(opt, value)
- def __getattr__(self, key):
- """get zmq options by attribute"""
- upper_key = key.upper()
- try:
- opt = getattr(constants, upper_key)
- except AttributeError:
- raise AttributeError("%s has no such option: %s" % (
- self.__class__.__name__, upper_key)
- )
- else:
- from zmq import ZMQError
- try:
- return self._get_attr_opt(upper_key, opt)
- except ZMQError as e:
- # EINVAL will be raised on access for write-only attributes.
- # Turn that into an AttributeError
- # necessary for mocking
- if e.errno == errno.EINVAL:
- raise AttributeError("{} attribute is write-only".format(key))
- else:
- raise
- def _get_attr_opt(self, name, opt):
- """override if getattr should do something other than call self.get"""
- return self.get(opt)
- __all__ = ['AttributeSetter']
|