2018-05-17 08:25:43 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import ssl
|
|
|
|
import zipfile
|
|
|
|
import hashlib
|
|
|
|
import urllib.request
|
|
|
|
|
|
|
|
# Disable certificate checking because it always fails on Windows
|
|
|
|
# We verify the checksum anyway.
|
|
|
|
ctx = ssl.create_default_context()
|
|
|
|
ctx.check_hostname = False
|
|
|
|
ctx.verify_mode = ssl.CERT_NONE
|
|
|
|
|
2019-09-15 02:35:29 +00:00
|
|
|
base_url = 'https://github.com/lexxmark/winflexbison/releases/download/v{0}/win_flex_bison-{0}.zip'
|
2018-05-17 08:25:43 +00:00
|
|
|
url = base_url.format(sys.argv[1])
|
|
|
|
zip_sha256 = sys.argv[2]
|
|
|
|
source_dir = os.path.join(os.environ['MESON_SOURCE_ROOT'], os.environ['MESON_SUBDIR'])
|
|
|
|
dest = os.path.basename(url)
|
|
|
|
dest_path = os.path.join(source_dir, dest)
|
|
|
|
|
|
|
|
def get_sha256(zipf):
|
|
|
|
hasher = hashlib.sha256()
|
|
|
|
with open(zipf, 'rb') as f:
|
|
|
|
hasher.update(f.read())
|
|
|
|
return hasher.hexdigest()
|
|
|
|
|
|
|
|
if os.path.isfile(dest_path):
|
|
|
|
found_sha256 = get_sha256(dest_path)
|
|
|
|
if found_sha256 == zip_sha256:
|
|
|
|
print('{} already downloaded'.format(dest))
|
|
|
|
sys.exit(0)
|
|
|
|
else:
|
|
|
|
print('{} checksum mismatch, redownloading'.format(dest))
|
|
|
|
|
|
|
|
print('Downloading {} to {}'.format(url, dest))
|
|
|
|
with open(dest_path, 'wb') as d:
|
|
|
|
f = urllib.request.urlopen(url, context=ctx)
|
|
|
|
d.write(f.read())
|
|
|
|
|
|
|
|
found_sha256 = get_sha256(dest_path)
|
|
|
|
if found_sha256 != zip_sha256:
|
|
|
|
print('SHA256 of downloaded file {} was {} instead of {}'
|
|
|
|
''.format(dest, found_sha256, zip_sha256))
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
print('Extracting {}'.format(dest))
|
|
|
|
zf = zipfile.ZipFile(dest_path, "r")
|
|
|
|
zf.extractall(path=source_dir)
|