[bitbake-devel] [PATCH 2/3] bb.fetch: handle checksums consistently for mirrors
Christopher Larson
kergoth at gmail.com
Wed Aug 26 16:37:46 UTC 2015
From: Christopher Larson <chris_larson at mentor.com>
If the main fetch method doesn't support checksums, the user will not be
defining them in the recipe, so we don't want to check them for
premirrors/mirrors either. This ensures that we never error due to missing
checksums on a git mirror tarball.
Signed-off-by: Christopher Larson <chris_larson at mentor.com>
---
lib/bb/fetch2/__init__.py | 7 ++++---
1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/lib/bb/fetch2/__init__.py b/lib/bb/fetch2/__init__.py
index ec0c31a..e229c30 100644
--- a/lib/bb/fetch2/__init__.py
+++ b/lib/bb/fetch2/__init__.py
@@ -628,7 +628,7 @@ def verify_checksum(ud, d, precomputed={}):
}
-def verify_donestamp(ud, d):
+def verify_donestamp(ud, d, origud=None):
"""
Check whether the done stamp file has the right checksums (if the fetch
method supports them). If it doesn't, delete the done stamp and force
@@ -640,7 +640,8 @@ def verify_donestamp(ud, d):
if not os.path.exists(ud.donestamp):
return False
- if not ud.method.supports_checksum(ud):
+ if (not ud.method.supports_checksum(ud) or
+ (origud and not origud.method.supports_checksum(origud))):
# done stamp exists, checksums not supported; assume the local file is
# current
return True
@@ -922,7 +923,7 @@ def try_mirror_url(fetch, origud, ud, ld, check = False):
os.chdir(ld.getVar("DL_DIR", True))
- if not verify_donestamp(ud, ld) or ud.method.need_update(ud, ld):
+ if not verify_donestamp(ud, ld, origud) or ud.method.need_update(ud, ld):
ud.method.download(ud, ld)
if hasattr(ud.method,"build_mirror_data"):
ud.method.build_mirror_data(ud, ld)
--
2.2.1
More information about the bitbake-devel
mailing list