aboutsummaryrefslogtreecommitdiffstats
path: root/host
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2020-02-18 16:20:05 -0800
committeratrnati <54334261+atrnati@users.noreply.github.com>2020-02-19 11:52:32 -0600
commitba976443b65b775775193f0e91693c8af0e00fe8 (patch)
tree01472ca9bb07d543e68fbf8f94357b7809a14153 /host
parente6e1cad743d04f79148c92bab774fed183ff43a6 (diff)
downloaduhd-ba976443b65b775775193f0e91693c8af0e00fe8.tar.gz
uhd-ba976443b65b775775193f0e91693c8af0e00fe8.tar.bz2
uhd-ba976443b65b775775193f0e91693c8af0e00fe8.zip
utils: images downloader: Handle missing content-length response
If the content-length header is not available, uhd_images_downloader will now ask the user if she wants to continue. Previously, the tool would throw an exception.
Diffstat (limited to 'host')
-rw-r--r--host/utils/uhd_images_downloader.py.in25
1 files changed, 18 insertions, 7 deletions
diff --git a/host/utils/uhd_images_downloader.py.in b/host/utils/uhd_images_downloader.py.in
index 1983ef84c..29f559dfe 100644
--- a/host/utils/uhd_images_downloader.py.in
+++ b/host/utils/uhd_images_downloader.py.in
@@ -364,22 +364,28 @@ def download(
# requests library versions pre-4c3b9df6091b65d8c72763222bd5fdefb7231149
# (Dec.'12) workaround
resp = requests.get(images_url, prefetch=False, proxies=_PROXIES,
- headers={'User-Agent': 'UHD Images Downloader'})
+ headers={'User-Agent': 'UHD Images Downloader'},
+ allow_redirects=True)
if resp.status_code != 200:
raise RuntimeError("URL does not exist: {}".format(images_url))
- filesize = float(resp.headers['content-length'])
+ filesize = float(resp.headers.get('content-length', -1))
if filesize > download_limit:
if not ask_permission(
"The file size for this target ({:.1f} MiB) exceeds the "
"download limit ({:.1f} MiB). Continue downloading?".format(
filesize/1024**2, download_limit/1024**2)):
return 0, 0, ""
+ if filesize == -1:
+ if not ask_permission(
+ "The file size for this target could not be determined. "
+ "Continue downloading?"):
+ return 0, 0, ""
filesize_dl = 0
base_filename = os.path.basename(filename)
if print_progress and not sys.stdout.isatty():
print_progress = False
log("INFO", "Downloading {}, total size: {} kB".format(
- base_filename, filesize/1000))
+ base_filename, filesize/1000 if filesize > 0 else "-unknown-"))
with open(filename, "wb") as temp_file:
sha256_sum = hashlib.sha256()
for buff in resp.iter_content(chunk_size=buffer_size):
@@ -388,10 +394,13 @@ def download(
filesize_dl += len(buff)
sha256_sum.update(buff)
if print_progress:
- status = r"%05d kB / %05d kB (%03d%%) %s" % (
- int(math.ceil(filesize_dl / 1000.)), int(math.ceil(filesize / 1000.)),
- int(math.ceil(filesize_dl * 100.) / filesize),
- base_filename)
+ status = r"%05d kB " % int(math.ceil(filesize_dl / 1000.))
+ if filesize > 0:
+ status += r"/ %05d kB (%03d%%) " % (
+ int(math.ceil(filesize / 1000.)),
+ int(math.ceil(filesize_dl * 100.) / filesize),
+ )
+ status += base_filename
if os.name == "nt":
status += chr(8) * (len(status) + 1)
else:
@@ -400,6 +409,8 @@ def download(
sys.stdout.flush()
if print_progress:
print('')
+ if filesize <= 0:
+ filesize = filesize_dl
return filesize, filesize_dl, sha256_sum.hexdigest()