Merge pull request #688 from JackDandy/feature/ChangeTimezoneTypeCheck

Change check for parameter types in parse_date_time.
This commit is contained in:
JackDandy 2016-05-02 19:29:20 +01:00
commit f3fc3f4b7a

View file

@ -266,7 +266,7 @@ def get_network_timezone(network):
except: except:
pass pass
return timezone if timezone is not None else sb_timezone return timezone if isinstance(timezone, datetime.tzinfo) else sb_timezone
def parse_time(t): def parse_time(t):
@ -306,17 +306,17 @@ def parse_time(t):
# parse date and time string into local time # parse date and time string into local time
def parse_date_time(d, t, network): def parse_date_time(d, t, network):
if isinstance(t, basestring): if isinstance(t, tuple) and len(t) == 2 and isinstance(t[0], int) and isinstance(t[1], int):
(hr, m) = parse_time(t)
else:
(hr, m) = t (hr, m) = t
else:
(hr, m) = parse_time(t)
te = datetime.datetime.fromordinal(helpers.tryInt(d)) te = datetime.datetime.fromordinal(helpers.tryInt(d))
try: try:
if isinstance(network, basestring): if isinstance(network, datetime.tzinfo):
foreign_timezone = get_network_timezone(network)
else:
foreign_timezone = network foreign_timezone = network
else:
foreign_timezone = get_network_timezone(network)
foreign_naive = datetime.datetime(te.year, te.month, te.day, hr, m, tzinfo=foreign_timezone) foreign_naive = datetime.datetime(te.year, te.month, te.day, hr, m, tzinfo=foreign_timezone)
return foreign_naive return foreign_naive
except: except: