Change check for parameter types in parse_date_time.

This commit is contained in:
Prinz23 2016-05-02 01:23:15 +02:00 committed by JackDandy
parent 567b551903
commit 66824acc5e

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: