2020-04-24 19:58:47 +00:00
|
|
|
import re
|
|
|
|
|
2018-10-07 10:12:47 +00:00
|
|
|
def metric_or_imperial(query, lang, us_ip=False):
|
|
|
|
"""
|
|
|
|
"""
|
|
|
|
|
|
|
|
# what units should be used
|
|
|
|
# metric or imperial
|
|
|
|
# based on query and location source (imperial for US by default)
|
|
|
|
if query.get('use_metric', False) and not query.get('use_imperial', False):
|
|
|
|
query['use_imperial'] = False
|
|
|
|
query['use_metric'] = True
|
|
|
|
elif query.get('use_imperial', False) and not query.get('use_metric', False):
|
|
|
|
query['use_imperial'] = True
|
|
|
|
query['use_metric'] = False
|
|
|
|
elif lang == 'us':
|
|
|
|
# slack uses m by default, to override it speciy us.wttr.in
|
|
|
|
query['use_imperial'] = True
|
|
|
|
query['use_metric'] = False
|
|
|
|
else:
|
|
|
|
if us_ip:
|
|
|
|
query['use_imperial'] = True
|
|
|
|
query['use_metric'] = False
|
|
|
|
else:
|
|
|
|
query['use_imperial'] = False
|
|
|
|
query['use_metric'] = True
|
|
|
|
|
|
|
|
return query
|
2017-03-12 16:42:22 +00:00
|
|
|
|
|
|
|
def parse_query(args):
|
|
|
|
result = {}
|
|
|
|
|
|
|
|
reserved_args = ["lang"]
|
|
|
|
|
|
|
|
q = ""
|
|
|
|
|
|
|
|
for key, val in args.items():
|
|
|
|
if len(val) == 0:
|
|
|
|
q += key
|
|
|
|
continue
|
|
|
|
if val == 'True':
|
|
|
|
val = True
|
|
|
|
if val == 'False':
|
|
|
|
val = False
|
|
|
|
result[key] = val
|
|
|
|
|
|
|
|
if q is None:
|
|
|
|
return result
|
2019-02-01 11:29:27 +00:00
|
|
|
if 'A' in q:
|
|
|
|
result['force-ansi'] = True
|
2017-03-12 16:42:22 +00:00
|
|
|
if 'n' in q:
|
|
|
|
result['narrow'] = True
|
|
|
|
if 'm' in q:
|
|
|
|
result['use_metric'] = True
|
2017-03-24 22:59:49 +00:00
|
|
|
if 'M' in q:
|
|
|
|
result['use_ms_for_wind'] = True
|
2017-03-12 16:42:22 +00:00
|
|
|
if 'u' in q:
|
|
|
|
result['use_imperial'] = True
|
|
|
|
if 'I' in q:
|
|
|
|
result['inverted_colors'] = True
|
|
|
|
if 't' in q:
|
|
|
|
result['transparency'] = '150'
|
2017-03-22 15:16:21 +00:00
|
|
|
if 'T' in q:
|
|
|
|
result['no-terminal'] = True
|
2017-03-12 16:42:22 +00:00
|
|
|
if 'p' in q:
|
|
|
|
result['padding'] = True
|
|
|
|
|
|
|
|
for days in "0123":
|
|
|
|
if days in q:
|
|
|
|
result['days'] = days
|
|
|
|
|
|
|
|
result['no-caption'] = False
|
|
|
|
result['no-city'] = False
|
|
|
|
if 'q' in q:
|
|
|
|
result['no-caption'] = True
|
|
|
|
if 'Q' in q:
|
|
|
|
result['no-city'] = True
|
2019-01-11 11:48:00 +00:00
|
|
|
if 'F' in q:
|
|
|
|
result['no-follow-line'] = True
|
2017-03-12 16:42:22 +00:00
|
|
|
|
|
|
|
for key, val in args.items():
|
|
|
|
if val == 'True':
|
|
|
|
val = True
|
|
|
|
if val == 'False':
|
|
|
|
val = False
|
|
|
|
result[key] = val
|
|
|
|
|
2020-04-25 20:28:28 +00:00
|
|
|
# currently `view` is alias for `format`
|
|
|
|
if "format" in result and not result.get("view"):
|
|
|
|
result["view"] = result["format"]
|
|
|
|
del result["format"]
|
|
|
|
|
2017-03-12 16:42:22 +00:00
|
|
|
return result
|
|
|
|
|
2020-04-24 19:58:47 +00:00
|
|
|
def parse_wttrin_png_name(name):
|
|
|
|
"""
|
|
|
|
Parse the PNG filename and return the result as a dictionary.
|
|
|
|
For example:
|
|
|
|
input = City_200x_lang=ru.png
|
|
|
|
output = {
|
|
|
|
"lang": "ru",
|
|
|
|
"width": "200",
|
|
|
|
"filetype": "png",
|
|
|
|
"location": "City"
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
|
|
|
|
parsed = {}
|
|
|
|
to_be_parsed = {}
|
|
|
|
|
|
|
|
if name.lower()[-4:] == '.png':
|
|
|
|
parsed['filetype'] = 'png'
|
|
|
|
name = name[:-4]
|
|
|
|
|
|
|
|
parts = name.split('_')
|
|
|
|
parsed['location'] = parts[0]
|
|
|
|
|
2020-04-27 17:19:41 +00:00
|
|
|
one_letter_options = ""
|
2020-04-24 19:58:47 +00:00
|
|
|
for part in parts[1:]:
|
|
|
|
if re.match('(?:[0-9]+)x', part):
|
|
|
|
parsed['width'] = part[:-1]
|
|
|
|
elif re.match('x(?:[0-9]+)', part):
|
|
|
|
parsed['height'] = part[1:]
|
|
|
|
elif re.match(part, '(?:[0-9]+)x(?:[0-9]+)'):
|
|
|
|
parsed['width'], parsed['height'] = part.split('x', 1)
|
|
|
|
elif '=' in part:
|
|
|
|
arg, val = part.split('=', 1)
|
|
|
|
to_be_parsed[arg] = val
|
|
|
|
else:
|
2020-04-27 17:19:41 +00:00
|
|
|
one_letter_options += part
|
|
|
|
|
|
|
|
for letter in one_letter_options:
|
|
|
|
to_be_parsed[letter] = ''
|
2020-04-24 19:58:47 +00:00
|
|
|
|
|
|
|
parsed.update(parse_query(to_be_parsed))
|
|
|
|
|
2020-04-25 20:28:28 +00:00
|
|
|
# currently `view` is alias for `format`
|
|
|
|
if "format" in parsed and not parsed.get("view"):
|
|
|
|
parsed["view"] = parsed["format"]
|
|
|
|
del parsed["format"]
|
|
|
|
|
2020-04-24 19:58:47 +00:00
|
|
|
return parsed
|