703d9c47a8
Change-Id: I4fad015181f15e4ffb9c9607723a1313a041621b Reviewed-on: https://skia-review.googlesource.com/103763 Reviewed-by: Stephan Altmueller <stephana@google.com> Commit-Queue: Hal Canary <halcanary@google.com>
72 lines
2.2 KiB
Python
Executable File
72 lines
2.2 KiB
Python
Executable File
#! /usr/bin/env python
|
|
|
|
# Copyright 2018 Google Inc.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
import hashlib
|
|
import multiprocessing
|
|
import os
|
|
import shutil
|
|
import sys
|
|
import tempfile
|
|
import urllib2
|
|
|
|
def checksum(path):
|
|
if not os.path.exists(path):
|
|
return None
|
|
m = hashlib.md5()
|
|
with open(path, 'rb') as f:
|
|
while True:
|
|
buf = f.read(4096)
|
|
if 0 == len(buf):
|
|
return m.hexdigest()
|
|
m.update(buf)
|
|
|
|
def download(md5, path):
|
|
if not md5 == checksum(path):
|
|
dirname = os.path.dirname(path)
|
|
if dirname and not os.path.exists(dirname):
|
|
try:
|
|
os.makedirs(dirname)
|
|
except:
|
|
# ignore race condition
|
|
if not os.path.exists(dirname):
|
|
raise
|
|
url = 'https://storage.googleapis.com/skia-skqp-assets/' + md5
|
|
with open(path, 'wb') as o:
|
|
shutil.copyfileobj(urllib2.urlopen(url), o)
|
|
|
|
def tmp(prefix):
|
|
fd, path = tempfile.mkstemp(prefix=prefix)
|
|
os.close(fd)
|
|
return path
|
|
|
|
def main():
|
|
target_dir = os.path.join('platform_tools', 'android', 'apps', 'skqp', 'src', 'main', 'assets')
|
|
os.chdir(os.path.join(os.path.dirname(__file__), os.pardir, os.pardir, target_dir))
|
|
checksum_path = 'files.checksum'
|
|
if not os.path.isfile(checksum_path):
|
|
sys.stderr.write('Error: "%s" is missing.\n' % os.path.join(target_dir, checksum_path))
|
|
sys.exit(1)
|
|
file_list_file = tmp('files_')
|
|
with open(checksum_path, 'r') as f:
|
|
md5 = f.read().strip()
|
|
assert(len(md5) == 32)
|
|
download(md5, file_list_file)
|
|
with open(file_list_file, 'r') as f:
|
|
records = []
|
|
for line in f:
|
|
md5, path = line.strip().split(';', 1)
|
|
records.append((md5, path))
|
|
sys.stderr.write('Downloading %d files.\n' % len(records))
|
|
pool = multiprocessing.Pool(processes=multiprocessing.cpu_count() * 2)
|
|
for record in records:
|
|
pool.apply_async(download, record, callback=lambda x: sys.stderr.write('.'))
|
|
pool.close()
|
|
pool.join()
|
|
sys.stderr.write('\n')
|
|
|
|
if __name__ == '__main__':
|
|
main()
|