Fix PEP257 issues
parent
f6bc1a4575
commit
876978d64a
|
@ -1,9 +1,4 @@
|
||||||
"""
|
"""Helper methods for various modules."""
|
||||||
homeassistant.util
|
|
||||||
~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
Helper methods for various modules.
|
|
||||||
"""
|
|
||||||
import collections
|
import collections
|
||||||
from itertools import chain
|
from itertools import chain
|
||||||
import threading
|
import threading
|
||||||
|
@ -25,24 +20,24 @@ RE_SLUGIFY = re.compile(r'[^a-z0-9_]+')
|
||||||
|
|
||||||
|
|
||||||
def sanitize_filename(filename):
|
def sanitize_filename(filename):
|
||||||
""" Sanitizes a filename by removing .. / and \\. """
|
r"""Sanitize a filename by removing .. / and \\."""
|
||||||
return RE_SANITIZE_FILENAME.sub("", filename)
|
return RE_SANITIZE_FILENAME.sub("", filename)
|
||||||
|
|
||||||
|
|
||||||
def sanitize_path(path):
|
def sanitize_path(path):
|
||||||
""" Sanitizes a path by removing ~ and .. """
|
"""Sanitize a path by removing ~ and .."""
|
||||||
return RE_SANITIZE_PATH.sub("", path)
|
return RE_SANITIZE_PATH.sub("", path)
|
||||||
|
|
||||||
|
|
||||||
def slugify(text):
|
def slugify(text):
|
||||||
""" Slugifies a given text. """
|
"""Slugify a given text."""
|
||||||
text = text.lower().replace(" ", "_")
|
text = text.lower().replace(" ", "_")
|
||||||
|
|
||||||
return RE_SLUGIFY.sub("", text)
|
return RE_SLUGIFY.sub("", text)
|
||||||
|
|
||||||
|
|
||||||
def repr_helper(inp):
|
def repr_helper(inp):
|
||||||
""" Helps creating a more readable string representation of objects. """
|
"""Help creating a more readable string representation of objects."""
|
||||||
if isinstance(inp, (dict, MappingProxyType)):
|
if isinstance(inp, (dict, MappingProxyType)):
|
||||||
return ", ".join(
|
return ", ".join(
|
||||||
repr_helper(key)+"="+repr_helper(item) for key, item
|
repr_helper(key)+"="+repr_helper(item) for key, item
|
||||||
|
@ -54,7 +49,7 @@ def repr_helper(inp):
|
||||||
|
|
||||||
|
|
||||||
def convert(value, to_type, default=None):
|
def convert(value, to_type, default=None):
|
||||||
""" Converts value to to_type, returns default if fails. """
|
"""Convert value to to_type, returns default if fails."""
|
||||||
try:
|
try:
|
||||||
return default if value is None else to_type(value)
|
return default if value is None else to_type(value)
|
||||||
except (ValueError, TypeError):
|
except (ValueError, TypeError):
|
||||||
|
@ -63,8 +58,10 @@ def convert(value, to_type, default=None):
|
||||||
|
|
||||||
|
|
||||||
def ensure_unique_string(preferred_string, current_strings):
|
def ensure_unique_string(preferred_string, current_strings):
|
||||||
""" Returns a string that is not present in current_strings.
|
"""Return a string that is not present in current_strings.
|
||||||
If preferred string exists will append _2, _3, .. """
|
|
||||||
|
If preferred string exists will append _2, _3, ..
|
||||||
|
"""
|
||||||
test_string = preferred_string
|
test_string = preferred_string
|
||||||
current_strings = set(current_strings)
|
current_strings = set(current_strings)
|
||||||
|
|
||||||
|
@ -79,7 +76,7 @@ def ensure_unique_string(preferred_string, current_strings):
|
||||||
|
|
||||||
# Taken from: http://stackoverflow.com/a/11735897
|
# Taken from: http://stackoverflow.com/a/11735897
|
||||||
def get_local_ip():
|
def get_local_ip():
|
||||||
""" Tries to determine the local IP address of the machine. """
|
"""Try to determine the local IP address of the machine."""
|
||||||
try:
|
try:
|
||||||
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
||||||
|
|
||||||
|
@ -95,7 +92,7 @@ def get_local_ip():
|
||||||
|
|
||||||
# Taken from http://stackoverflow.com/a/23728630
|
# Taken from http://stackoverflow.com/a/23728630
|
||||||
def get_random_string(length=10):
|
def get_random_string(length=10):
|
||||||
""" Returns a random string with letters and digits. """
|
"""Return a random string with letters and digits."""
|
||||||
generator = random.SystemRandom()
|
generator = random.SystemRandom()
|
||||||
source_chars = string.ascii_letters + string.digits
|
source_chars = string.ascii_letters + string.digits
|
||||||
|
|
||||||
|
@ -103,34 +100,39 @@ def get_random_string(length=10):
|
||||||
|
|
||||||
|
|
||||||
class OrderedEnum(enum.Enum):
|
class OrderedEnum(enum.Enum):
|
||||||
""" Taken from Python 3.4.0 docs. """
|
"""Taken from Python 3.4.0 docs."""
|
||||||
# pylint: disable=no-init, too-few-public-methods
|
|
||||||
|
|
||||||
|
# pylint: disable=no-init, too-few-public-methods
|
||||||
def __ge__(self, other):
|
def __ge__(self, other):
|
||||||
|
"""Return the greater than element."""
|
||||||
if self.__class__ is other.__class__:
|
if self.__class__ is other.__class__:
|
||||||
return self.value >= other.value
|
return self.value >= other.value
|
||||||
return NotImplemented
|
return NotImplemented
|
||||||
|
|
||||||
def __gt__(self, other):
|
def __gt__(self, other):
|
||||||
|
"""Return the greater element."""
|
||||||
if self.__class__ is other.__class__:
|
if self.__class__ is other.__class__:
|
||||||
return self.value > other.value
|
return self.value > other.value
|
||||||
return NotImplemented
|
return NotImplemented
|
||||||
|
|
||||||
def __le__(self, other):
|
def __le__(self, other):
|
||||||
|
"""Return the lower than element."""
|
||||||
if self.__class__ is other.__class__:
|
if self.__class__ is other.__class__:
|
||||||
return self.value <= other.value
|
return self.value <= other.value
|
||||||
return NotImplemented
|
return NotImplemented
|
||||||
|
|
||||||
def __lt__(self, other):
|
def __lt__(self, other):
|
||||||
|
"""Return the lower element."""
|
||||||
if self.__class__ is other.__class__:
|
if self.__class__ is other.__class__:
|
||||||
return self.value < other.value
|
return self.value < other.value
|
||||||
return NotImplemented
|
return NotImplemented
|
||||||
|
|
||||||
|
|
||||||
class OrderedSet(collections.MutableSet):
|
class OrderedSet(collections.MutableSet):
|
||||||
""" Ordered set taken from http://code.activestate.com/recipes/576694/ """
|
"""Ordered set taken from http://code.activestate.com/recipes/576694/."""
|
||||||
|
|
||||||
def __init__(self, iterable=None):
|
def __init__(self, iterable=None):
|
||||||
|
"""Initialize the set."""
|
||||||
self.end = end = []
|
self.end = end = []
|
||||||
end += [None, end, end] # sentinel node for doubly linked list
|
end += [None, end, end] # sentinel node for doubly linked list
|
||||||
self.map = {} # key --> [key, prev, next]
|
self.map = {} # key --> [key, prev, next]
|
||||||
|
@ -138,20 +140,22 @@ class OrderedSet(collections.MutableSet):
|
||||||
self |= iterable
|
self |= iterable
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
|
"""Return the length of the set."""
|
||||||
return len(self.map)
|
return len(self.map)
|
||||||
|
|
||||||
def __contains__(self, key):
|
def __contains__(self, key):
|
||||||
|
"""Check if key is in set."""
|
||||||
return key in self.map
|
return key in self.map
|
||||||
|
|
||||||
def add(self, key):
|
def add(self, key):
|
||||||
""" Add an element to the end of the set. """
|
"""Add an element to the end of the set."""
|
||||||
if key not in self.map:
|
if key not in self.map:
|
||||||
end = self.end
|
end = self.end
|
||||||
curr = end[1]
|
curr = end[1]
|
||||||
curr[2] = end[1] = self.map[key] = [key, curr, end]
|
curr[2] = end[1] = self.map[key] = [key, curr, end]
|
||||||
|
|
||||||
def promote(self, key):
|
def promote(self, key):
|
||||||
""" Promote element to beginning of the set, add if not there. """
|
"""Promote element to beginning of the set, add if not there."""
|
||||||
if key in self.map:
|
if key in self.map:
|
||||||
self.discard(key)
|
self.discard(key)
|
||||||
|
|
||||||
|
@ -160,13 +164,14 @@ class OrderedSet(collections.MutableSet):
|
||||||
curr[2] = begin[1] = self.map[key] = [key, curr, begin]
|
curr[2] = begin[1] = self.map[key] = [key, curr, begin]
|
||||||
|
|
||||||
def discard(self, key):
|
def discard(self, key):
|
||||||
""" Discard an element from the set. """
|
"""Discard an element from the set."""
|
||||||
if key in self.map:
|
if key in self.map:
|
||||||
key, prev_item, next_item = self.map.pop(key)
|
key, prev_item, next_item = self.map.pop(key)
|
||||||
prev_item[2] = next_item
|
prev_item[2] = next_item
|
||||||
next_item[1] = prev_item
|
next_item[1] = prev_item
|
||||||
|
|
||||||
def __iter__(self):
|
def __iter__(self):
|
||||||
|
"""Iteration of the set."""
|
||||||
end = self.end
|
end = self.end
|
||||||
curr = end[2]
|
curr = end[2]
|
||||||
while curr is not end:
|
while curr is not end:
|
||||||
|
@ -174,6 +179,7 @@ class OrderedSet(collections.MutableSet):
|
||||||
curr = curr[2]
|
curr = curr[2]
|
||||||
|
|
||||||
def __reversed__(self):
|
def __reversed__(self):
|
||||||
|
"""reverse the ordering."""
|
||||||
end = self.end
|
end = self.end
|
||||||
curr = end[1]
|
curr = end[1]
|
||||||
while curr is not end:
|
while curr is not end:
|
||||||
|
@ -181,8 +187,8 @@ class OrderedSet(collections.MutableSet):
|
||||||
curr = curr[1]
|
curr = curr[1]
|
||||||
|
|
||||||
def pop(self, last=True): # pylint: disable=arguments-differ
|
def pop(self, last=True): # pylint: disable=arguments-differ
|
||||||
"""
|
"""Pop element of the end of the set.
|
||||||
Pops element of the end of the set.
|
|
||||||
Set last=False to pop from the beginning.
|
Set last=False to pop from the beginning.
|
||||||
"""
|
"""
|
||||||
if not self:
|
if not self:
|
||||||
|
@ -192,24 +198,27 @@ class OrderedSet(collections.MutableSet):
|
||||||
return key
|
return key
|
||||||
|
|
||||||
def update(self, *args):
|
def update(self, *args):
|
||||||
""" Add elements from args to the set. """
|
"""Add elements from args to the set."""
|
||||||
for item in chain(*args):
|
for item in chain(*args):
|
||||||
self.add(item)
|
self.add(item)
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
|
"""Return the representation."""
|
||||||
if not self:
|
if not self:
|
||||||
return '%s()' % (self.__class__.__name__,)
|
return '%s()' % (self.__class__.__name__,)
|
||||||
return '%s(%r)' % (self.__class__.__name__, list(self))
|
return '%s(%r)' % (self.__class__.__name__, list(self))
|
||||||
|
|
||||||
def __eq__(self, other):
|
def __eq__(self, other):
|
||||||
|
"""Return the comparision."""
|
||||||
if isinstance(other, OrderedSet):
|
if isinstance(other, OrderedSet):
|
||||||
return len(self) == len(other) and list(self) == list(other)
|
return len(self) == len(other) and list(self) == list(other)
|
||||||
return set(self) == set(other)
|
return set(self) == set(other)
|
||||||
|
|
||||||
|
|
||||||
class Throttle(object):
|
class Throttle(object):
|
||||||
"""
|
"""A class for throttling the execution of tasks.
|
||||||
A method decorator to add a cooldown to a method to prevent it from being
|
|
||||||
|
This method decorator adds a cooldown to a method to prevent it from being
|
||||||
called more then 1 time within the timedelta interval `min_time` after it
|
called more then 1 time within the timedelta interval `min_time` after it
|
||||||
returned its result.
|
returned its result.
|
||||||
|
|
||||||
|
@ -223,13 +232,15 @@ class Throttle(object):
|
||||||
|
|
||||||
Adds a datetime attribute `last_call` to the method.
|
Adds a datetime attribute `last_call` to the method.
|
||||||
"""
|
"""
|
||||||
# pylint: disable=too-few-public-methods
|
|
||||||
|
|
||||||
|
# pylint: disable=too-few-public-methods
|
||||||
def __init__(self, min_time, limit_no_throttle=None):
|
def __init__(self, min_time, limit_no_throttle=None):
|
||||||
|
"""Initialize the throttle."""
|
||||||
self.min_time = min_time
|
self.min_time = min_time
|
||||||
self.limit_no_throttle = limit_no_throttle
|
self.limit_no_throttle = limit_no_throttle
|
||||||
|
|
||||||
def __call__(self, method):
|
def __call__(self, method):
|
||||||
|
"""Caller for the throttle."""
|
||||||
if self.limit_no_throttle is not None:
|
if self.limit_no_throttle is not None:
|
||||||
method = Throttle(self.limit_no_throttle)(method)
|
method = Throttle(self.limit_no_throttle)(method)
|
||||||
|
|
||||||
|
@ -248,8 +259,8 @@ class Throttle(object):
|
||||||
|
|
||||||
@wraps(method)
|
@wraps(method)
|
||||||
def wrapper(*args, **kwargs):
|
def wrapper(*args, **kwargs):
|
||||||
"""
|
"""Wrapper that allows wrapped to be called only once per min_time.
|
||||||
Wrapper that allows wrapped to be called only once per min_time.
|
|
||||||
If we cannot acquire the lock, it is running so return None.
|
If we cannot acquire the lock, it is running so return None.
|
||||||
"""
|
"""
|
||||||
# pylint: disable=protected-access
|
# pylint: disable=protected-access
|
||||||
|
@ -288,10 +299,11 @@ class Throttle(object):
|
||||||
|
|
||||||
class ThreadPool(object):
|
class ThreadPool(object):
|
||||||
"""A priority queue-based thread pool."""
|
"""A priority queue-based thread pool."""
|
||||||
# pylint: disable=too-many-instance-attributes
|
|
||||||
|
|
||||||
|
# pylint: disable=too-many-instance-attributes
|
||||||
def __init__(self, job_handler, worker_count=0, busy_callback=None):
|
def __init__(self, job_handler, worker_count=0, busy_callback=None):
|
||||||
"""
|
"""Initialize the pool.
|
||||||
|
|
||||||
job_handler: method to be called from worker thread to handle job
|
job_handler: method to be called from worker thread to handle job
|
||||||
worker_count: number of threads to run that handle jobs
|
worker_count: number of threads to run that handle jobs
|
||||||
busy_callback: method to be called when queue gets too big.
|
busy_callback: method to be called when queue gets too big.
|
||||||
|
@ -338,18 +350,18 @@ class ThreadPool(object):
|
||||||
self.busy_warning_limit = self.worker_count * 3
|
self.busy_warning_limit = self.worker_count * 3
|
||||||
|
|
||||||
def add_job(self, priority, job):
|
def add_job(self, priority, job):
|
||||||
""" Add a job to the queue. """
|
"""Add a job to the queue."""
|
||||||
with self._lock:
|
with self._lock:
|
||||||
if not self.running:
|
if not self.running:
|
||||||
raise RuntimeError("ThreadPool not running")
|
raise RuntimeError("ThreadPool not running")
|
||||||
|
|
||||||
self._work_queue.put(PriorityQueueItem(priority, job))
|
self._work_queue.put(PriorityQueueItem(priority, job))
|
||||||
|
|
||||||
# check if our queue is getting too big
|
# Check if our queue is getting too big.
|
||||||
if self._work_queue.qsize() > self.busy_warning_limit \
|
if self._work_queue.qsize() > self.busy_warning_limit \
|
||||||
and self._busy_callback is not None:
|
and self._busy_callback is not None:
|
||||||
|
|
||||||
# Increase limit we will issue next warning
|
# Increase limit we will issue next warning.
|
||||||
self.busy_warning_limit *= 2
|
self.busy_warning_limit *= 2
|
||||||
|
|
||||||
self._busy_callback(
|
self._busy_callback(
|
||||||
|
@ -404,12 +416,14 @@ class ThreadPool(object):
|
||||||
|
|
||||||
|
|
||||||
class PriorityQueueItem(object):
|
class PriorityQueueItem(object):
|
||||||
""" Holds a priority and a value. Used within PriorityQueue. """
|
"""Holds a priority and a value. Used within PriorityQueue."""
|
||||||
|
|
||||||
# pylint: disable=too-few-public-methods
|
# pylint: disable=too-few-public-methods
|
||||||
def __init__(self, priority, item):
|
def __init__(self, priority, item):
|
||||||
|
"""Initialize the queue."""
|
||||||
self.priority = priority
|
self.priority = priority
|
||||||
self.item = item
|
self.item = item
|
||||||
|
|
||||||
def __lt__(self, other):
|
def __lt__(self, other):
|
||||||
|
"""Return the ordering."""
|
||||||
return self.priority < other.priority
|
return self.priority < other.priority
|
||||||
|
|
|
@ -1,10 +1,4 @@
|
||||||
"""
|
"""Provides helper methods to handle the time in HA."""
|
||||||
homeassistant.util.dt
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
Provides helper methods to handle the time in HA.
|
|
||||||
|
|
||||||
"""
|
|
||||||
import datetime as dt
|
import datetime as dt
|
||||||
|
|
||||||
import pytz
|
import pytz
|
||||||
|
@ -16,7 +10,7 @@ UTC = DEFAULT_TIME_ZONE = pytz.utc
|
||||||
|
|
||||||
|
|
||||||
def set_default_time_zone(time_zone):
|
def set_default_time_zone(time_zone):
|
||||||
""" Sets a default time zone to be used when none is specified. """
|
"""Set a default time zone to be used when none is specified."""
|
||||||
global DEFAULT_TIME_ZONE # pylint: disable=global-statement
|
global DEFAULT_TIME_ZONE # pylint: disable=global-statement
|
||||||
|
|
||||||
assert isinstance(time_zone, dt.tzinfo)
|
assert isinstance(time_zone, dt.tzinfo)
|
||||||
|
@ -25,7 +19,7 @@ def set_default_time_zone(time_zone):
|
||||||
|
|
||||||
|
|
||||||
def get_time_zone(time_zone_str):
|
def get_time_zone(time_zone_str):
|
||||||
""" Get time zone from string. Return None if unable to determine. """
|
"""Get time zone from string. Return None if unable to determine."""
|
||||||
try:
|
try:
|
||||||
return pytz.timezone(time_zone_str)
|
return pytz.timezone(time_zone_str)
|
||||||
except pytz.exceptions.UnknownTimeZoneError:
|
except pytz.exceptions.UnknownTimeZoneError:
|
||||||
|
@ -33,18 +27,20 @@ def get_time_zone(time_zone_str):
|
||||||
|
|
||||||
|
|
||||||
def utcnow():
|
def utcnow():
|
||||||
""" Get now in UTC time. """
|
"""Get now in UTC time."""
|
||||||
return dt.datetime.now(UTC)
|
return dt.datetime.now(UTC)
|
||||||
|
|
||||||
|
|
||||||
def now(time_zone=None):
|
def now(time_zone=None):
|
||||||
""" Get now in specified time zone. """
|
"""Get now in specified time zone."""
|
||||||
return dt.datetime.now(time_zone or DEFAULT_TIME_ZONE)
|
return dt.datetime.now(time_zone or DEFAULT_TIME_ZONE)
|
||||||
|
|
||||||
|
|
||||||
def as_utc(dattim):
|
def as_utc(dattim):
|
||||||
""" Return a datetime as UTC time.
|
"""Return a datetime as UTC time.
|
||||||
Assumes datetime without tzinfo to be in the DEFAULT_TIME_ZONE. """
|
|
||||||
|
Assumes datetime without tzinfo to be in the DEFAULT_TIME_ZONE.
|
||||||
|
"""
|
||||||
if dattim.tzinfo == UTC:
|
if dattim.tzinfo == UTC:
|
||||||
return dattim
|
return dattim
|
||||||
elif dattim.tzinfo is None:
|
elif dattim.tzinfo is None:
|
||||||
|
@ -54,7 +50,7 @@ def as_utc(dattim):
|
||||||
|
|
||||||
|
|
||||||
def as_local(dattim):
|
def as_local(dattim):
|
||||||
""" Converts a UTC datetime object to local time_zone. """
|
"""Convert a UTC datetime object to local time zone."""
|
||||||
if dattim.tzinfo == DEFAULT_TIME_ZONE:
|
if dattim.tzinfo == DEFAULT_TIME_ZONE:
|
||||||
return dattim
|
return dattim
|
||||||
elif dattim.tzinfo is None:
|
elif dattim.tzinfo is None:
|
||||||
|
@ -64,12 +60,12 @@ def as_local(dattim):
|
||||||
|
|
||||||
|
|
||||||
def utc_from_timestamp(timestamp):
|
def utc_from_timestamp(timestamp):
|
||||||
""" Returns a UTC time from a timestamp. """
|
"""Return a UTC time from a timestamp."""
|
||||||
return dt.datetime.utcfromtimestamp(timestamp).replace(tzinfo=UTC)
|
return dt.datetime.utcfromtimestamp(timestamp).replace(tzinfo=UTC)
|
||||||
|
|
||||||
|
|
||||||
def start_of_local_day(dt_or_d=None):
|
def start_of_local_day(dt_or_d=None):
|
||||||
""" Return local datetime object of start of day from date or datetime. """
|
"""Return local datetime object of start of day from date or datetime."""
|
||||||
if dt_or_d is None:
|
if dt_or_d is None:
|
||||||
dt_or_d = now().date()
|
dt_or_d = now().date()
|
||||||
elif isinstance(dt_or_d, dt.datetime):
|
elif isinstance(dt_or_d, dt.datetime):
|
||||||
|
@ -80,12 +76,12 @@ def start_of_local_day(dt_or_d=None):
|
||||||
|
|
||||||
|
|
||||||
def datetime_to_local_str(dattim):
|
def datetime_to_local_str(dattim):
|
||||||
""" Converts datetime to specified time_zone and returns a string. """
|
"""Convert datetime to specified time_zone and returns a string."""
|
||||||
return datetime_to_str(as_local(dattim))
|
return datetime_to_str(as_local(dattim))
|
||||||
|
|
||||||
|
|
||||||
def datetime_to_str(dattim):
|
def datetime_to_str(dattim):
|
||||||
""" Converts datetime to a string format.
|
"""Convert datetime to a string format.
|
||||||
|
|
||||||
@rtype : str
|
@rtype : str
|
||||||
"""
|
"""
|
||||||
|
@ -93,7 +89,7 @@ def datetime_to_str(dattim):
|
||||||
|
|
||||||
|
|
||||||
def datetime_to_time_str(dattim):
|
def datetime_to_time_str(dattim):
|
||||||
""" Converts datetime to a string containing only the time.
|
"""Convert datetime to a string containing only the time.
|
||||||
|
|
||||||
@rtype : str
|
@rtype : str
|
||||||
"""
|
"""
|
||||||
|
@ -101,7 +97,7 @@ def datetime_to_time_str(dattim):
|
||||||
|
|
||||||
|
|
||||||
def datetime_to_date_str(dattim):
|
def datetime_to_date_str(dattim):
|
||||||
""" Converts datetime to a string containing only the date.
|
"""Convert datetime to a string containing only the date.
|
||||||
|
|
||||||
@rtype : str
|
@rtype : str
|
||||||
"""
|
"""
|
||||||
|
@ -109,7 +105,7 @@ def datetime_to_date_str(dattim):
|
||||||
|
|
||||||
|
|
||||||
def str_to_datetime(dt_str, dt_format=DATETIME_STR_FORMAT):
|
def str_to_datetime(dt_str, dt_format=DATETIME_STR_FORMAT):
|
||||||
""" Converts a string to a UTC datetime object.
|
"""Convert a string to a UTC datetime object.
|
||||||
|
|
||||||
@rtype: datetime
|
@rtype: datetime
|
||||||
"""
|
"""
|
||||||
|
@ -121,7 +117,7 @@ def str_to_datetime(dt_str, dt_format=DATETIME_STR_FORMAT):
|
||||||
|
|
||||||
|
|
||||||
def date_str_to_date(dt_str):
|
def date_str_to_date(dt_str):
|
||||||
""" Converts a date string to a date object. """
|
"""Convert a date string to a date object."""
|
||||||
try:
|
try:
|
||||||
return dt.datetime.strptime(dt_str, DATE_STR_FORMAT).date()
|
return dt.datetime.strptime(dt_str, DATE_STR_FORMAT).date()
|
||||||
except ValueError: # If dt_str did not match our format
|
except ValueError: # If dt_str did not match our format
|
||||||
|
@ -129,12 +125,13 @@ def date_str_to_date(dt_str):
|
||||||
|
|
||||||
|
|
||||||
def strip_microseconds(dattim):
|
def strip_microseconds(dattim):
|
||||||
""" Returns a copy of dattime object but with microsecond set to 0. """
|
"""Return a copy of dattime object but with microsecond set to 0."""
|
||||||
return dattim.replace(microsecond=0)
|
return dattim.replace(microsecond=0)
|
||||||
|
|
||||||
|
|
||||||
def parse_time_str(time_str):
|
def parse_time_str(time_str):
|
||||||
""" Parse a time string (00:20:00) into Time object.
|
"""Parse a time string (00:20:00) into Time object.
|
||||||
|
|
||||||
Return None if invalid.
|
Return None if invalid.
|
||||||
"""
|
"""
|
||||||
parts = str(time_str).split(':')
|
parts = str(time_str).split(':')
|
||||||
|
|
|
@ -1,8 +1,4 @@
|
||||||
"""
|
"""Helpers to install PyPi packages."""
|
||||||
homeassistant.util.package
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
Helpers to install PyPi packages.
|
|
||||||
"""
|
|
||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
import subprocess
|
import subprocess
|
||||||
|
@ -17,8 +13,8 @@ INSTALL_LOCK = threading.Lock()
|
||||||
|
|
||||||
|
|
||||||
def install_package(package, upgrade=True, target=None):
|
def install_package(package, upgrade=True, target=None):
|
||||||
"""
|
"""Install a package on PyPi. Accepts pip compatible package strings.
|
||||||
Install a package on PyPi. Accepts pip compatible package strings.
|
|
||||||
Return boolean if install successful.
|
Return boolean if install successful.
|
||||||
"""
|
"""
|
||||||
# Not using 'import pip; pip.main([])' because it breaks the logger
|
# Not using 'import pip; pip.main([])' because it breaks the logger
|
||||||
|
@ -41,8 +37,8 @@ def install_package(package, upgrade=True, target=None):
|
||||||
|
|
||||||
|
|
||||||
def check_package_exists(package, lib_dir):
|
def check_package_exists(package, lib_dir):
|
||||||
"""
|
"""Check if a package is installed globally or in lib_dir.
|
||||||
Check if a package is installed globally or in lib_dir.
|
|
||||||
Returns True when the requirement is met.
|
Returns True when the requirement is met.
|
||||||
Returns False when the package is not installed or doesn't meet req.
|
Returns False when the package is not installed or doesn't meet req.
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,15 +1,11 @@
|
||||||
"""
|
"""Temperature util functions."""
|
||||||
homeassistant.util.temperature
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
Temperature util functions.
|
|
||||||
"""
|
|
||||||
|
|
||||||
|
|
||||||
def fahrenheit_to_celcius(fahrenheit):
|
def fahrenheit_to_celcius(fahrenheit):
|
||||||
""" Convert a Fahrenheit temperature to Celcius. """
|
"""Convert a Fahrenheit temperature to Celsius."""
|
||||||
return (fahrenheit - 32.0) / 1.8
|
return (fahrenheit - 32.0) / 1.8
|
||||||
|
|
||||||
|
|
||||||
def celcius_to_fahrenheit(celcius):
|
def celcius_to_fahrenheit(celcius):
|
||||||
""" Convert a Celcius temperature to Fahrenheit. """
|
"""Convert a Celsius temperature to Fahrenheit."""
|
||||||
return celcius * 1.8 + 32.0
|
return celcius * 1.8 + 32.0
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
"""
|
"""YAML utility functions."""
|
||||||
YAML utility functions.
|
|
||||||
"""
|
|
||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
|
@ -26,8 +24,7 @@ def load_yaml(fname):
|
||||||
|
|
||||||
|
|
||||||
def _include_yaml(loader, node):
|
def _include_yaml(loader, node):
|
||||||
"""
|
"""Load another YAML file and embeds it using the !include tag.
|
||||||
Loads another YAML file and embeds it using the !include tag.
|
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
device_tracker: !include device_tracker.yaml
|
device_tracker: !include device_tracker.yaml
|
||||||
|
@ -37,9 +34,7 @@ def _include_yaml(loader, node):
|
||||||
|
|
||||||
|
|
||||||
def _ordered_dict(loader, node):
|
def _ordered_dict(loader, node):
|
||||||
"""
|
"""Load YAML mappings into an ordered dict to preserve key order."""
|
||||||
Loads YAML mappings into an ordered dict to preserve key order.
|
|
||||||
"""
|
|
||||||
loader.flatten_mapping(node)
|
loader.flatten_mapping(node)
|
||||||
return OrderedDict(loader.construct_pairs(node))
|
return OrderedDict(loader.construct_pairs(node))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue