| Viewing file:  convert.py (2.63 KB)      -rw-r--r-- Select action/file-type:
 
  (+) |  (+) |  (+) | Code (+) | Session (+) |  (+) | SDB (+) |  (+) |  (+) |  (+) |  (+) |  (+) | 
 
from __future__ import absolute_import, unicode_literals
 import logging
 import os
 
 
 class TypeData(object):
 def __init__(self, default_type, as_type):
 self.default_type = default_type
 self.as_type = as_type
 
 def __repr__(self):
 return "{}(base={}, as={})".format(self.__class__.__name__, self.default_type, self.as_type)
 
 def convert(self, value):
 return self.default_type(value)
 
 
 class BoolType(TypeData):
 BOOLEAN_STATES = {
 "1": True,
 "yes": True,
 "true": True,
 "on": True,
 "0": False,
 "no": False,
 "false": False,
 "off": False,
 }
 
 def convert(self, value):
 if value.lower() not in self.BOOLEAN_STATES:
 raise ValueError("Not a boolean: %s" % value)
 return self.BOOLEAN_STATES[value.lower()]
 
 
 class NoneType(TypeData):
 def convert(self, value):
 if not value:
 return None
 return str(value)
 
 
 class ListType(TypeData):
 def _validate(self):
 """ """
 
 def convert(self, value, flatten=True):
 values = self.split_values(value)
 result = []
 for value in values:
 sub_values = value.split(os.pathsep)
 result.extend(sub_values)
 converted = [self.as_type(i) for i in result]
 return converted
 
 def split_values(self, value):
 """Split the provided value into a list.
 
 First this is done by newlines. If there were no newlines in the text,
 then we next try to split by comma.
 """
 if isinstance(value, (str, bytes)):
 # Use `splitlines` rather than a custom check for whether there is
 # more than one line. This ensures that the full `splitlines()`
 # logic is supported here.
 values = value.splitlines()
 if len(values) <= 1:
 values = value.split(",")
 values = filter(None, [x.strip() for x in values])
 else:
 values = list(value)
 
 return values
 
 
 def convert(value, as_type, source):
 """Convert the value as a given type where the value comes from the given source"""
 try:
 return as_type.convert(value)
 except Exception as exception:
 logging.warning("%s failed to convert %r as %r because %r", source, value, as_type, exception)
 raise
 
 
 _CONVERT = {bool: BoolType, type(None): NoneType, list: ListType}
 
 
 def get_type(action):
 default_type = type(action.default)
 as_type = default_type if action.type is None else action.type
 return _CONVERT.get(default_type, TypeData)(default_type, as_type)
 
 
 __all__ = (
 "convert",
 "get_type",
 )
 
 |