Skip to content

Commit

Permalink
show extraction progress
Browse files Browse the repository at this point in the history
  • Loading branch information
christianrauch committed Feb 17, 2024
1 parent 322d3a2 commit e364f64
Showing 1 changed file with 25 additions and 2 deletions.
27 changes: 25 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@
import py7zr
import requests
import yaml
from tqdm_loggable.auto import tqdm
from tqdm_loggable.tqdm_logging import tqdm_logging


url_repo_qtc_fmt = "https://download.qt.io/{release_type}_releases/qtcreator/{qtcv_maj}/{qtcv_full}/installer_source/{os}_{arch}/"

Expand Down Expand Up @@ -47,6 +50,26 @@ def read_downloadable_archives(package):
archive_names = io.StringIO(package.find("DownloadableArchives").text)
return list(csv.reader(archive_names, delimiter=',', skipinitialspace=True))[0]

def extract_progress(archive_bytes, archive_name, destination_path):
class ExtractProgressBar(py7zr.callbacks.ExtractCallback, tqdm):
def __init__(self, *args, total_bytes, **kwargs):
super().__init__(self, *args, total=total_bytes, **kwargs)
def report_start_preparation(self):
pass
def report_start(self, processing_file_path, processing_bytes):
pass
def report_end(self, processing_file_path, wrote_bytes):
self.update(int(wrote_bytes))
def report_postprocess(self):
pass
def report_warning(self, message):
pass

zf = py7zr.SevenZipFile(io.BytesIO(archive_bytes))
total_bytes=sum([f.uncompressed for f in zf.files])
cb_progress = ExtractProgressBar(unit='B', unit_scale=True, miniters=1, total_bytes=total_bytes, desc=archive_name)
zf.extractall(path=destination_path, callback=cb_progress)

def qtc_download_check_extract(cfg, dir_install):
# if the Qt Creator version contains '-beta' or '-rc' we have to
# use the "development" repo, otherwise use the "official" repo
Expand Down Expand Up @@ -92,7 +115,7 @@ def qtc_download_check_extract(cfg, dir_install):
if md5sums[archive_name] != hashlib.md5(content).hexdigest():
raise RuntimeError(archive_name+" MD5 hash sum does not match")

py7zr.SevenZipFile(io.BytesIO(content)).extractall(dir_install_qt)
extract_progress(content, archive_name, dir_install_qt)

if cfg['os'] == "Darwin":
dir_install_qt = os.path.join(dir_install_qt, "Qt Creator.app", "Contents", "Resources")
Expand Down Expand Up @@ -168,7 +191,7 @@ def qt_download_check_extract(cfg, dir_install):
if sha1sum != hashlib.sha1(content).hexdigest():
raise RuntimeError(archive_name+" SHA1 hash sum does not match")

py7zr.SevenZipFile(io.BytesIO(content)).extractall(dir_install)
extract_progress(content, archive_name, dir_install)

qt_path = os.path.join(dir_install, "{}.{}.0".format(ver_maj, ver_min))
qt_archs = os.listdir(qt_path)
Expand Down

0 comments on commit e364f64

Please sign in to comment.