src_distribute classes: store sources in tmp/deploy/sources/LICENSE dirs
authorMarcin Juszkiewicz <hrw@openedhand.com>
Tue, 5 Jun 2007 16:23:20 +0000 (16:23 +0000)
committerMarcin Juszkiewicz <hrw@openedhand.com>
Tue, 5 Jun 2007 16:23:20 +0000 (16:23 +0000)
- recipe with few licenses has source stored in few directories
- recipes without LICENSE have source stored in "unknown" directory

git-svn-id: https://svn.o-hand.com/repos/poky/trunk@1862 311d38ba-8fff-0310-9ca6-ca027cbcb966

meta/classes/src_distribute.bbclass
meta/classes/src_distribute_local.bbclass

index 5daf526..157e22b 100644 (file)
@@ -1,40 +1,21 @@
-include conf/licenses.conf
-
 SRC_DISTRIBUTECOMMAND[func] = "1"
 python do_distribute_sources () {
        l = bb.data.createCopy(d)
        bb.data.update_data(l)
-       licenses = (bb.data.getVar('LICENSE', d, 1) or "").split()
-       if not licenses:
-               bb.note("LICENSE not defined")
-       src_distribute_licenses = (bb.data.getVar('SRC_DISTRIBUTE_LICENSES', d, 1) or "").split()
-       # Explanation:
-       # Space seperated items in LICENSE must *all* be distributable
-       # Each space seperated item may be used under any number of | seperated licenses.
-       # If any of those | seperated licenses are distributable, then that component is.
-       # i.e. LICENSE = "GPL LGPL"
-       #     In this case, both components are distributable.
-       # LICENSE = "GPL|QPL|Proprietary"
-       #     In this case, GPL is distributable, so the component is.
-       valid = 1
+       licenses = (bb.data.getVar('LICENSE', d, 1) or "unknown").split()
+
+       sources_dir = bb.data.getVar('SRC_DISTRIBUTEDIR', d, 1)
+       import re
        for l in licenses:
-               lvalid = 0
                for i in l.split("|"):
-                       if i in src_distribute_licenses:
-                               lvalid = 1
-               if lvalid != 1:
-                       valid = 0
-       if valid == 0:
-               bb.note("Licenses (%s) are not all listed in SRC_DISTRIBUTE_LICENSES, skipping source distribution" % licenses)
-               return
-       import re
-       for s in (bb.data.getVar('A', d, 1) or "").split():
-               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.build.exec_func('SRC_DISTRIBUTECOMMAND', d)
+                       for s in (bb.data.getVar('A', d, 1) or "").split():
+                               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, l), d)
+                               bb.build.exec_func('SRC_DISTRIBUTECOMMAND', d)
 }
 
 addtask distribute_sources before do_build after do_fetch
index 5f0cef5..31cc85f 100644 (file)
@@ -1,3 +1,5 @@
+SRC_DISTRIBUTEDIR ?= "${DEPLOY_DIR}/sources"
+
 inherit src_distribute
 
 # SRC_DIST_LOCAL possible values:
@@ -5,7 +7,7 @@ inherit src_distribute
 # symlink      symlinks the files from ${A} to the distributedir
 # move+symlink moves the files into distributedir, and symlinks them back
 SRC_DIST_LOCAL ?= "move+symlink"
-SRC_DISTRIBUTEDIR ?= "${DEPLOY_DIR}/sources"
+
 SRC_DISTRIBUTECOMMAND () {
        s="${SRC}"
        if [ ! -L "$s" ] && (echo "$s"|grep "^${DL_DIR}"); then