diff options
Diffstat (limited to 'classes/src_distribute.bbclass')
| -rw-r--r-- | classes/src_distribute.bbclass | 55 |
1 files changed, 34 insertions, 21 deletions
diff --git a/classes/src_distribute.bbclass b/classes/src_distribute.bbclass index 30b2670011..795a5cfe4e 100644 --- a/classes/src_distribute.bbclass +++ b/classes/src_distribute.bbclass @@ -1,29 +1,42 @@ +SRC_DISTRIBUTE_DLONLY ?= "0" SRC_DISTRIBUTECOMMAND[func] = "1" + +addtask distribute_sources before do_build after do_fetch python do_distribute_sources () { - l = bb.data.createCopy(d) - bb.data.update_data(l) + bb.build.exec_func("do_fetch", d) + + cmd = bb.data.getVar('SRC_DISTRIBUTECOMMAND', d, 1) + if not cmd: + raise bb.build.FuncFailed("Unable to distribute sources, SRC_DISTRIBUTECOMMAND not set") + + try: + dlonly = int(d.getVar("SRC_DISTRIBUTE_DLONLY", 1)) + except ValueError: + raise bb.build.FuncFailed("Invalid value for SRC_DISTRIBUTE_DLONLY: expected integer.") + dldir = os.path.realpath(d.getVar("DL_DIR", 1) or "") + licenses = (bb.data.getVar('LICENSE', d, 1) or "unknown").split() + urldatadict = bb.fetch.init(d.getVar("SRC_URI", True).split(), d, True) + for url, urldata in urldatadict.iteritems(): + if not urldata.setup: + urldata.setup_localpath(d) + + local = urldata.localpath + if dlonly and dldir and not \ + os.path.realpath(local).startswith(dldir + os.path.sep): + continue - sources_dir = bb.data.getVar('SRC_DISTRIBUTEDIR', d, 1) - import re - for license in licenses: - for entry in license.split("|"): - for url in ((bb.data.getVar('SRC_URI', d, 1) or '').split()): - bb.fetch.init([url], d) - s = bb.fetch.localpath(url, d) - s = re.sub(';.*$', '', s) - cmd = bb.data.getVar('SRC_DISTRIBUTECOMMAND', d, 1) - if not cmd: - raise bb.build.FuncFailed("Unable to distribute sources, SRC_DISTRIBUTECOMMAND not defined") - bb.data.setVar('SRC', s, d) - bb.data.setVar('SRC_DISTRIBUTEDIR', "%s/%s" % (sources_dir, entry), d) + bb.data.setVar('SRC', os.path.abspath(local), d) + for license in licenses: + for entry in license.split("|"): + bb.data.setVar('LIC', entry, d) bb.build.exec_func('SRC_DISTRIBUTECOMMAND', d) } -addtask distribute_sources before do_build after do_fetch +addtask distribute_sources_all after do_distribute_sources +do_distribute_sources_all[recrdeptask] = "do_distribute_sources" +do_distribute_sources_all[nostamp] = "1" -addtask distsrcall after do_distribute_sources -do_distsrcall[recrdeptask] = "do_distribute_sources" -base_do_distsrcall() { - : -} +# compatability wrapper +addtask distsrcall after do_distribute_sources_all +do_distsrcall[nostamp] = "1" |
