summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--bitbake/lib/bb/fetch2/__init__.py38
1 files changed, 19 insertions, 19 deletions
diff --git a/bitbake/lib/bb/fetch2/__init__.py b/bitbake/lib/bb/fetch2/__init__.py
index b9f673c214..ae99b722aa 100644
--- a/bitbake/lib/bb/fetch2/__init__.py
+++ b/bitbake/lib/bb/fetch2/__init__.py
@@ -507,7 +507,7 @@ def fetcher_compare_revisions(d):
507def mirror_from_string(data): 507def mirror_from_string(data):
508 return [ i.split() for i in (data or "").replace('\\n','\n').split('\n') if i ] 508 return [ i.split() for i in (data or "").replace('\\n','\n').split('\n') if i ]
509 509
510def verify_checksum(u, ud, d): 510def verify_checksum(ud, d):
511 """ 511 """
512 verify the MD5 and SHA256 checksum for downloaded src 512 verify the MD5 and SHA256 checksum for downloaded src
513 513
@@ -530,7 +530,7 @@ def verify_checksum(u, ud, d):
530 raise NoChecksumError('No checksum specified for %s, please add at least one to the recipe:\n' 530 raise NoChecksumError('No checksum specified for %s, please add at least one to the recipe:\n'
531 'SRC_URI[%s] = "%s"\nSRC_URI[%s] = "%s"' % 531 'SRC_URI[%s] = "%s"\nSRC_URI[%s] = "%s"' %
532 (ud.localpath, ud.md5_name, md5data, 532 (ud.localpath, ud.md5_name, md5data,
533 ud.sha256_name, sha256data), u) 533 ud.sha256_name, sha256data), ud.url)
534 534
535 # Log missing sums so user can more easily add them 535 # Log missing sums so user can more easily add them
536 if ud.md5_expected == None: 536 if ud.md5_expected == None:
@@ -568,10 +568,10 @@ def verify_checksum(u, ud, d):
568 msg = msg + '\nIf this change is expected (e.g. you have upgraded to a new version without updating the checksums) then you can use these lines within the recipe:\nSRC_URI[%s] = "%s"\nSRC_URI[%s] = "%s"\nOtherwise you should retry the download and/or check with upstream to determine if the file has become corrupted or otherwise unexpectedly modified.\n' % (ud.md5_name, md5data, ud.sha256_name, sha256data) 568 msg = msg + '\nIf this change is expected (e.g. you have upgraded to a new version without updating the checksums) then you can use these lines within the recipe:\nSRC_URI[%s] = "%s"\nSRC_URI[%s] = "%s"\nOtherwise you should retry the download and/or check with upstream to determine if the file has become corrupted or otherwise unexpectedly modified.\n' % (ud.md5_name, md5data, ud.sha256_name, sha256data)
569 569
570 if len(msg): 570 if len(msg):
571 raise ChecksumError('Checksum mismatch!%s' % msg, u, md5data) 571 raise ChecksumError('Checksum mismatch!%s' % msg, ud.url, md5data)
572 572
573 573
574def update_stamp(u, ud, d): 574def update_stamp(ud, d):
575 """ 575 """
576 donestamp is file stamp indicating the whole fetching is done 576 donestamp is file stamp indicating the whole fetching is done
577 this function update the stamp after verifying the checksum 577 this function update the stamp after verifying the checksum
@@ -584,7 +584,7 @@ def update_stamp(u, ud, d):
584 # Errors aren't fatal here 584 # Errors aren't fatal here
585 pass 585 pass
586 else: 586 else:
587 verify_checksum(u, ud, d) 587 verify_checksum(ud, d)
588 open(ud.donestamp, 'w').close() 588 open(ud.donestamp, 'w').close()
589 589
590def subprocess_setup(): 590def subprocess_setup():
@@ -730,7 +730,7 @@ def build_mirroruris(origud, mirrors, ld):
730 replacements["BASENAME"] = origud.path.split("/")[-1] 730 replacements["BASENAME"] = origud.path.split("/")[-1]
731 replacements["MIRRORNAME"] = origud.host.replace(':','.') + origud.path.replace('/', '.').replace('*', '.') 731 replacements["MIRRORNAME"] = origud.host.replace(':','.') + origud.path.replace('/', '.').replace('*', '.')
732 732
733 def adduri(uri, ud, uris, uds): 733 def adduri(ud, uris, uds):
734 for line in mirrors: 734 for line in mirrors:
735 try: 735 try:
736 (find, replace) = line 736 (find, replace) = line
@@ -753,9 +753,9 @@ def build_mirroruris(origud, mirrors, ld):
753 uris.append(newuri) 753 uris.append(newuri)
754 uds.append(newud) 754 uds.append(newud)
755 755
756 adduri(newuri, newud, uris, uds) 756 adduri(newud, uris, uds)
757 757
758 adduri(None, origud, uris, uds) 758 adduri(origud, uris, uds)
759 759
760 return uris, uds 760 return uris, uds
761 761
@@ -772,22 +772,22 @@ def rename_bad_checksum(ud, suffix):
772 bb.utils.movefile(ud.localpath, new_localpath) 772 bb.utils.movefile(ud.localpath, new_localpath)
773 773
774 774
775def try_mirror_url(newuri, origud, ud, ld, check = False): 775def try_mirror_url(origud, ud, ld, check = False):
776 # Return of None or a value means we're finished 776 # Return of None or a value means we're finished
777 # False means try another url 777 # False means try another url
778 try: 778 try:
779 if check: 779 if check:
780 found = ud.method.checkstatus(newuri, ud, ld) 780 found = ud.method.checkstatus(ud.url, ud, ld)
781 if found: 781 if found:
782 return found 782 return found
783 return False 783 return False
784 784
785 os.chdir(ld.getVar("DL_DIR", True)) 785 os.chdir(ld.getVar("DL_DIR", True))
786 786
787 if not os.path.exists(ud.donestamp) or ud.method.need_update(newuri, ud, ld): 787 if not os.path.exists(ud.donestamp) or ud.method.need_update(ud.url, ud, ld):
788 ud.method.download(newuri, ud, ld) 788 ud.method.download(ud.url, ud, ld)
789 if hasattr(ud.method,"build_mirror_data"): 789 if hasattr(ud.method,"build_mirror_data"):
790 ud.method.build_mirror_data(newuri, ud, ld) 790 ud.method.build_mirror_data(ud.url, ud, ld)
791 791
792 if not ud.localpath or not os.path.exists(ud.localpath): 792 if not ud.localpath or not os.path.exists(ud.localpath):
793 return False 793 return False
@@ -817,7 +817,7 @@ def try_mirror_url(newuri, origud, ud, ld, check = False):
817 os.unlink(origud.localpath) 817 os.unlink(origud.localpath)
818 818
819 os.symlink(ud.localpath, origud.localpath) 819 os.symlink(ud.localpath, origud.localpath)
820 update_stamp(newuri, origud, ld) 820 update_stamp(origud, ld)
821 return ud.localpath 821 return ud.localpath
822 822
823 except bb.fetch2.NetworkAccess: 823 except bb.fetch2.NetworkAccess:
@@ -825,13 +825,13 @@ def try_mirror_url(newuri, origud, ud, ld, check = False):
825 825
826 except bb.fetch2.BBFetchException as e: 826 except bb.fetch2.BBFetchException as e:
827 if isinstance(e, ChecksumError): 827 if isinstance(e, ChecksumError):
828 logger.warn("Mirror checksum failure for url %s (original url: %s)\nCleaning and trying again." % (newuri, origud.url)) 828 logger.warn("Mirror checksum failure for url %s (original url: %s)\nCleaning and trying again." % (ud.url, origud.url))
829 logger.warn(str(e)) 829 logger.warn(str(e))
830 rename_bad_checksum(ud, e.checksum) 830 rename_bad_checksum(ud, e.checksum)
831 elif isinstance(e, NoChecksumError): 831 elif isinstance(e, NoChecksumError):
832 raise 832 raise
833 else: 833 else:
834 logger.debug(1, "Mirror fetch failure for url %s (original url: %s)" % (newuri, origud.url)) 834 logger.debug(1, "Mirror fetch failure for url %s (original url: %s)" % (ud.url, origud.url))
835 logger.debug(1, str(e)) 835 logger.debug(1, str(e))
836 try: 836 try:
837 ud.method.clean(ud, ld) 837 ud.method.clean(ud, ld)
@@ -853,7 +853,7 @@ def try_mirrors(d, origud, mirrors, check = False):
853 uris, uds = build_mirroruris(origud, mirrors, ld) 853 uris, uds = build_mirroruris(origud, mirrors, ld)
854 854
855 for index, uri in enumerate(uris): 855 for index, uri in enumerate(uris):
856 ret = try_mirror_url(uri, origud, uds[index], ld, check) 856 ret = try_mirror_url(origud, uds[index], ld, check)
857 if ret != False: 857 if ret != False:
858 return ret 858 return ret
859 return None 859 return None
@@ -1394,7 +1394,7 @@ class Fetch(object):
1394 localpath = ud.localpath 1394 localpath = ud.localpath
1395 # early checksum verify, so that if checksum mismatched, 1395 # early checksum verify, so that if checksum mismatched,
1396 # fetcher still have chance to fetch from mirror 1396 # fetcher still have chance to fetch from mirror
1397 update_stamp(u, ud, self.d) 1397 update_stamp(ud, self.d)
1398 1398
1399 except bb.fetch2.NetworkAccess: 1399 except bb.fetch2.NetworkAccess:
1400 raise 1400 raise
@@ -1421,7 +1421,7 @@ class Fetch(object):
1421 logger.error(str(firsterr)) 1421 logger.error(str(firsterr))
1422 raise FetchError("Unable to fetch URL from any source.", u) 1422 raise FetchError("Unable to fetch URL from any source.", u)
1423 1423
1424 update_stamp(u, ud, self.d) 1424 update_stamp(ud, self.d)
1425 1425
1426 except BBFetchException as e: 1426 except BBFetchException as e:
1427 if isinstance(e, NoChecksumError): 1427 if isinstance(e, NoChecksumError):