[oe-commits] [openembedded-core] 05/06: meta: license: fix non-SPDX license being removed from INCOMPATIBLE_LICENSE

git at git.openembedded.org git at git.openembedded.org
Tue Jun 11 08:42:17 UTC 2019


This is an automated email from the git hooks/post-receive script.

rpurdie pushed a commit to branch master-next
in repository openembedded-core.

commit 333a8ec378b98166001c8f5c5930bb6dbca5a100
Author: Quentin Schulz <quentin.schulz at streamunlimited.com>
AuthorDate: Tue Jun 11 10:11:46 2019 +0200

    meta: license: fix non-SPDX license being removed from INCOMPATIBLE_LICENSE
    
    A non-SPDX license (which is not an alias to an SPDX license) cannot
    currently be marked as incompatible in INCOMPATIBLE_LICENSE.
    In the current state, we take all INCOMPATIBLE_LICENSE and pass them
    through expand_wildcard_licenses which is only adding SPDX licenses that
    match the glob regexp of what is in INCOMPATIBLE_LICENSE (be it a direct
    match to an SPDX license or via an alias).
    
    This does not work well with custom licenses.
    
    E.g.:
    
    foo.bb:
    LICENSE = "FooLicense"
    
    conf/local.conf:
    INCOMPATIBLE_LICENSE = "FooLicense"
    
    `bitbake foo`
    
    Gives no warning, no error, builds and packages successfully, because
    INCOMPATIBLE_LICENSE is basically empty since FooLicense is neither in
    SPDXLICENSEMAP nor in SRC_DISTRIBUTE_LICENSES.
    
    Let's add the original licenses to the list returned by
    expand_wildcard_licenses to be able to handle the aforementioned case.
    
    INCOMPATIBLE_LICENSE = "FooLicense GPLv2 GPLv3+" used to "resolve" to
    "GPLv2 GPLv3". It now resolves to "FooLicense GPLv2 GPLv3 GPLv3+" which
    fixes the issue with custom licenses not being in SPDXLICENSEMAP or
    SRC_DISTRIBUTE_LICENSES and thus being left out of the blacklisted
    licenses.
    
    I needed to pass a list to expand_wildcard_licenses from the
    license_image class instead of the current output of map() because the
    operator [:] does not work on this kind of type, and list(map()) or
    anything that iterates over map() actually moves the iterator and breaks
    the forloop right after in expand_wildcard_licenses.
    
    Signed-off-by: Quentin Schulz <quentin.schulz at streamunlimited.com>
    Signed-off-by: Richard Purdie <richard.purdie at linuxfoundation.org>
---
 meta/classes/license.bbclass       | 2 +-
 meta/classes/license_image.bbclass | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/meta/classes/license.bbclass b/meta/classes/license.bbclass
index ed91a4b..adca881 100644
--- a/meta/classes/license.bbclass
+++ b/meta/classes/license.bbclass
@@ -268,7 +268,7 @@ def expand_wildcard_licenses(d, wildcard_licenses):
     wildcards from SPDXLICENSEMAP flags and SRC_DISTRIBUTE_LICENSES values.
     """
     import fnmatch
-    licenses = []
+    licenses = wildcard_licenses[:]
     spdxmapkeys = d.getVarFlags('SPDXLICENSEMAP').keys()
     for wld_lic in wildcard_licenses:
         spdxflags = fnmatch.filter(spdxmapkeys, wld_lic)
diff --git a/meta/classes/license_image.bbclass b/meta/classes/license_image.bbclass
index 6fb76be..2cfda81 100644
--- a/meta/classes/license_image.bbclass
+++ b/meta/classes/license_image.bbclass
@@ -40,7 +40,7 @@ def write_license_files(d, license_manifest, pkg_dic, rootfs=True):
     import stat
 
     bad_licenses = (d.getVar("INCOMPATIBLE_LICENSE") or "").split()
-    bad_licenses = map(lambda l: canonical_license(d, l), bad_licenses)
+    bad_licenses = [canonical_license(d, l) for l in bad_licenses]
     bad_licenses = expand_wildcard_licenses(d, bad_licenses)
 
     with open(license_manifest, "w") as license_file:

-- 
To stop receiving notification emails like this one, please contact
the administrator of this repository.


More information about the Openembedded-commits mailing list