Don't download SHA256 if it's already available locally
authorXimin Luo <infinity0@debian.org>
Tue, 1 Dec 2020 19:57:48 +0000 (19:57 +0000)
committerXimin Luo <infinity0@debian.org>
Tue, 1 Dec 2020 19:57:48 +0000 (19:57 +0000)
Forwarded: not-needed

In Debian we provide the stage0 tarballs as a separate component so that the
buildds don't need to access the network during the build.
Forwarded: not-needed
Gbp-Pq: Name d-dont-download-stage0.patch

src/bootstrap/bootstrap.py

index aed3f607b1ca838d32ad91f63dc967ad9aa026fa..c2637590253617c2d2e5cbaed748e0774a34ffeb 100644 (file)
@@ -24,17 +24,19 @@ def support_xz():
     except tarfile.CompressionError:
         return False
 
-def get(url, path, verbose=False, do_verify=True):
+def get(url, path, verbose=False, do_verify=True, use_local_hash_if_present=True):
     suffix = '.sha256'
     sha_url = url + suffix
     with tempfile.NamedTemporaryFile(delete=False) as temp_file:
         temp_path = temp_file.name
-    with tempfile.NamedTemporaryFile(suffix=suffix, delete=False) as sha_file:
-        sha_path = sha_file.name
+    sha_path = path + suffix
 
     try:
         if do_verify:
-            download(sha_path, sha_url, False, verbose)
+            if use_local_hash_if_present and os.path.exists(sha_path):
+                print("using already-download file " + sha_path)
+            else:
+                download(sha_path, sha_url, False, verbose)
             if os.path.exists(path):
                 if verify(path, sha_path, False):
                     if verbose:
@@ -52,7 +54,6 @@ def get(url, path, verbose=False, do_verify=True):
             print("moving {} to {}".format(temp_path, path))
         shutil.move(temp_path, path)
     finally:
-        delete_if_present(sha_path, verbose)
         delete_if_present(temp_path, verbose)
 
 
@@ -459,7 +460,7 @@ class RustBuild(object):
 
         url = "{}/dist/{}".format(self._download_url, date)
         tarball = os.path.join(rustc_cache, filename)
-        if not os.path.exists(tarball):
+        if True:
             get("{}/{}".format(url, filename), tarball, verbose=self.verbose)
         unpack(tarball, tarball_suffix, self.bin_root(), match=pattern, verbose=self.verbose)