diff options
Diffstat (limited to 'meta/classes')
-rw-r--r-- | meta/classes/sstate.bbclass | 52 |
1 files changed, 43 insertions, 9 deletions
diff --git a/meta/classes/sstate.bbclass b/meta/classes/sstate.bbclass index 7f897ae54d..4a63d37d20 100644 --- a/meta/classes/sstate.bbclass +++ b/meta/classes/sstate.bbclass @@ -254,14 +254,18 @@ def pstaging_fetch(sstatepkg, d): import bb.fetch # only try and fetch if the user has configured a mirror - if bb.data.getVar('SSTATE_MIRROR', d) != "": + + mirrors = bb.data.getVar('SSTATE_MIRRORS', d, True) + if mirrors: # Copy the data object and override DL_DIR and SRC_URI - pd = d.createCopy() - dldir = bb.data.expand("${SSTATE_DIR}", pd) - mirror = bb.data.expand("${SSTATE_MIRROR}/", pd) - srcuri = mirror + os.path.basename(sstatepkg) - bb.data.setVar('DL_DIR', dldir, pd) - bb.data.setVar('SRC_URI', srcuri, pd) + localdata = bb.data.createCopy(d) + bb.data.update_data(localdata) + + dldir = bb.data.expand("${SSTATE_DIR}", localdata) + srcuri = "file://" + os.path.basename(sstatepkg) + bb.data.setVar('DL_DIR', dldir, localdata) + bb.data.setVar('PREMIRRORS', mirrors, localdata) + bb.data.setVar('SRC_URI', srcuri, localdata) # Try a fetch from the sstate mirror, if it fails just return and # we will build the package @@ -269,7 +273,7 @@ def pstaging_fetch(sstatepkg, d): bb.fetch.init([srcuri], pd) bb.fetch.go(pd, [srcuri]) except: - return + pass def sstate_setscene(d): shared_state = sstate_state_fromvars(d) @@ -319,6 +323,7 @@ sstate_unpack_package () { BB_HASHCHECK_FUNCTION = "sstate_checkhashes" def sstate_checkhashes(sq_fn, sq_task, sq_hash, sq_hashfn, d): + ret = [] # This needs to go away, FIXME mapping = { @@ -332,10 +337,39 @@ def sstate_checkhashes(sq_fn, sq_task, sq_hash, sq_hashfn, d): for task in range(len(sq_fn)): sstatefile = bb.data.expand("${SSTATE_DIR}/" + sq_hashfn[task] + "_" + mapping[sq_task[task]] + ".tgz", d) - sstatefile= sstatefile.replace("${BB_TASKHASH}", sq_hash[task]) + sstatefile = sstatefile.replace("${BB_TASKHASH}", sq_hash[task]) #print("Checking for %s" % sstatefile) if os.path.exists(sstatefile): ret.append(task) + continue + + mirrors = bb.data.getVar("SSTATE_MIRRORS", d, True) + if mirrors: + # Copy the data object and override DL_DIR and SRC_URI + localdata = bb.data.createCopy(d) + bb.data.update_data(localdata) + + dldir = bb.data.expand("${SSTATE_DIR}", localdata) + bb.data.setVar('DL_DIR', dldir, localdata) + bb.data.setVar('PREMIRRORS', mirrors, localdata) + + for task in range(len(sq_fn)): + if task in ret: + continue + + sstatefile = bb.data.expand("${SSTATE_DIR}/" + sq_hashfn[task] + "_" + mapping[sq_task[task]] + ".tgz", d) + sstatefile = sstatefile.replace("${BB_TASKHASH}", sq_hash[task]) + + srcuri = "file://" + os.path.basename(sstatefile) + bb.data.setVar('SRC_URI', srcuri, localdata) + bb.note(str(srcuri)) + + try: + bb.fetch.init(srcuri.split(), d) + bb.fetch.checkstatus(localdata) + ret.append(task) + except: + pass return ret |