diff options
author | Chris Larson <chris_larson@mentor.com> | 2010-03-21 18:31:25 -0700 |
---|---|---|
committer | Chris Larson <chris_larson@mentor.com> | 2010-03-21 18:31:40 -0700 |
commit | d91b6bc42319db7799cf9188f7150f807ed41163 (patch) | |
tree | 3e478c7942c41699b454930dbba5c7000a8a38e9 /classes/src_distribute.bbclass | |
parent | 02630483284a2f31b01e636210715ee1fb6e63b9 (diff) | |
download | openembedded-d91b6bc42319db7799cf9188f7150f807ed41163.tar.gz |
src_distribute: simplify do_distribute_sources
Signed-off-by: Chris Larson <chris_larson@mentor.com>
Diffstat (limited to 'classes/src_distribute.bbclass')
-rw-r--r-- | classes/src_distribute.bbclass | 52 |
1 files changed, 24 insertions, 28 deletions
diff --git a/classes/src_distribute.bbclass b/classes/src_distribute.bbclass index 22044752ef..795a5cfe4e 100644 --- a/classes/src_distribute.bbclass +++ b/classes/src_distribute.bbclass @@ -3,38 +3,34 @@ SRC_DISTRIBUTECOMMAND[func] = "1" addtask distribute_sources before do_build after do_fetch python do_distribute_sources () { - import re - bb.build.exec_func("do_fetch", d) - l = bb.data.createCopy(d) - bb.data.update_data(l) + 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() - 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) - - try: - dlonly = int(d.getVar("SRC_DISTRIBUTE_DLONLY", 1)) - except ValueError: - raise bb.build.FuncFailed("Invalid value for SRC_DISTRIBUTE_DLONLY: expected integer.") - if dlonly: - dldir = os.path.realpath(d.getVar("DL_DIR", 1) or "") - if dldir and not \ - os.path.realpath(s).startswith(dldir + os.path.sep): - continue - - cmd = bb.data.getVar('SRC_DISTRIBUTECOMMAND', d, 1) - if not cmd: - raise bb.build.FuncFailed("Unable to distribute sources, SRC_DISTRIBUTECOMMAND not set") - bb.debug(2, "srcdist: running %s" % cmd) - bb.data.setVar('SRC', os.path.normpath(s), l) - bb.data.setVar('LIC', entry, l) - bb.build.exec_func('SRC_DISTRIBUTECOMMAND', l) + 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 + + 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_all after do_distribute_sources |