Source code for LMIConstantValues
# Copyright (C) 2012-2013 Peter Hatina <phatina@redhat.com>
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <http://www.gnu.org/licenses/>.
import abc
import sys
from LMIBaseObject import LMIBaseObject
from LMIUtil import lmi_cast_to_lmi
[docs]class LMIConstantValues(LMIBaseObject):
    """
    Abstract class for constant value objects.
    :param cim_obj: this object is either of type :py:class:`CIMParameter`,
        :py:class:`CIMProperty` or :py:class:`CIMMethod`. Construction of this
        object requires to have a member ``_cast_type`` to properly cast CIM
        object. When constructing derived objects, make sure, that the
        mentioned member is present before calling this constructor.
    :param cast_type: parameter/property cast type
    """
    __metaclass__ = abc.ABCMeta
    def __init__(self, cim_obj, cast_type):
        # Keys can contain various undesirable characters, such as python
        # operators, etc. So we drop them.
        keys = map(lambda v: "".join(c for c in v if c.isalnum()),
            cim_obj.qualifiers["Values"].value)
        values = cim_obj.qualifiers["ValueMap"].value
        self._value_map = {}
        self._value_map_inv = {}
        self._cast_type = cast_type
        # Fill two dictionaries for bidirectional access to constant values.
        for i in range(0, len(keys)):
            try:
                key = keys[i]
                val = lmi_cast_to_lmi(self._cast_type, values[i])
                self._value_map[key] = val
                self._value_map_inv[val] = key
            except ValueError, e:
                # Can not cast such value as interval. Can be found in
                # DMTFReserved, VendorReserved values.
                pass
    def __repr__(self):
        """
        Returns a string of all constant names with corresponding value.
        :returns: pretty string
        """
        result = ""
        for (k, v) in self._value_map.iteritems():
            result += "%s = %s\n" % (k, v)
        return result[:-1]
    def __getattr__(self, name):
        """
        Returns either a member of the class, or a constant value.
        Simplifies the code and constant value can be retrieved by
        :samp:`object.constant_value`.
        :param string name: member to retrieve
        :returns: class member
        """
        if name in self.__dict__:
            return self.__dict__[name]
        if name in self._value_map:
            return self._value_map[name]
        raise AttributeError(name)
[docs]    def print_values(self):
        """
        Prints all available constant names.
        **Usage:** :ref:`class_get_valuemap_properties`.
        """
        for k in self._value_map.keys():
            sys.stdout.write("%s\n" % k)
 
[docs]    def values_dict(self):
        """
        :returns: dictionary of constants' names and values
        """
        return self._value_map
 
[docs]    def values(self):
        """
        :returns: list of all available constant values
        """
        return self._value_map.keys()
 
[docs]    def value(self, value_name):
        """
        :param string value_name: constant name
        :returns: constant value
        **Usage:** :ref:`class_get_valuemap_property_value`.
        """
        return getattr(self, value_name)
 
[docs]    def value_name(self, value):
        """
        :param int value: numeric constant value
        :returns: constant value
        :rtype: string
        **Usage:** :ref:`class_get_valuemap_property_name`.
        """
        return self._value_map_inv[value]
  
[docs]class LMIConstantValuesParamProp(LMIConstantValues):
    """
    Derived class used for constant values of :py:class:`CIMProperty` and
    :py:class:`CIMParameter`.
    :param cim_property: :py:class:`CIMProperty` or :py:class:`CIMParameter`
        object. Both objects have necessary member ``type`` which is needed for
        proper casting.
    """
    def __init__(self, cim_property):
        super(LMIConstantValuesParamProp, self).__init__(cim_property, cim_property.type)
 
[docs]class LMIConstantValuesMethodReturnType(LMIConstantValues):
    """
    Derived class used for constant values of :py:class:`CIMMethod`.
    :param CIMMethod cim_method: :py:class:`CIMMethod` object
    """
    def __init__(self, cim_method):
        super(LMIConstantValuesMethodReturnType, self).__init__(cim_method, cim_method.return_type)