mirror of
https://git.yoctoproject.org/poky
synced 2026-05-30 12:29:55 +00:00
license: Add support for handle INCOMPATIBLE_LICENSE in manifest creation
When INCOMPATIBLE_LICENSE's is specified it need to be removed from license.manifest and also avoid copy to target image. Add ManifestVisitor that walk the license string searching for INCOMPATIBLE_LICENSE's if found remove it. [YOCTO #6765] (From OE-Core rev: d1278570041029d7c9fc6ce657e9a1701a421841) Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
bb3469f9d3
commit
b394cd4c7e
@@ -29,6 +29,10 @@ python license_create_manifest() {
|
|||||||
import re
|
import re
|
||||||
import oe.packagedata
|
import oe.packagedata
|
||||||
|
|
||||||
|
bad_licenses = (d.getVar("INCOMPATIBLE_LICENSE", True) or "").split()
|
||||||
|
bad_licenses = map(lambda l: canonical_license(d, l), bad_licenses)
|
||||||
|
bad_licenses = expand_wildcard_licenses(d, bad_licenses)
|
||||||
|
|
||||||
build_images_from_feeds = d.getVar('BUILD_IMAGES_FROM_FEEDS', True)
|
build_images_from_feeds = d.getVar('BUILD_IMAGES_FROM_FEEDS', True)
|
||||||
if build_images_from_feeds == "1":
|
if build_images_from_feeds == "1":
|
||||||
return 0
|
return 0
|
||||||
@@ -52,6 +56,18 @@ python license_create_manifest() {
|
|||||||
d.getVar('IMAGE_NAME', True), 'license.manifest')
|
d.getVar('IMAGE_NAME', True), 'license.manifest')
|
||||||
with open(license_manifest, "w") as license_file:
|
with open(license_manifest, "w") as license_file:
|
||||||
for pkg in sorted(pkg_dic):
|
for pkg in sorted(pkg_dic):
|
||||||
|
if bad_licenses:
|
||||||
|
try:
|
||||||
|
(pkg_dic[pkg]["LICENSE"], pkg_dic[pkg]["LICENSES"]) = \
|
||||||
|
oe.license.manifest_licenses(pkg_dic[pkg]["LICENSE"],
|
||||||
|
bad_licenses, canonical_license, d)
|
||||||
|
except oe.license.LicenseError as exc:
|
||||||
|
bb.fatal('%s: %s' % (d.getVar('P', True), exc))
|
||||||
|
else:
|
||||||
|
pkg_dic[pkg]["LICENSES"] = re.sub('[|&()*]', '', pkg_dic[pkg]["LICENSE"])
|
||||||
|
pkg_dic[pkg]["LICENSES"] = re.sub(' *', ' ', pkg_dic[pkg]["LICENSES"])
|
||||||
|
pkg_dic[pkg]["LICENSES"] = pkg_dic[pkg]["LICENSES"].split()
|
||||||
|
|
||||||
license_file.write("PACKAGE NAME: %s\n" % pkg)
|
license_file.write("PACKAGE NAME: %s\n" % pkg)
|
||||||
license_file.write("PACKAGE VERSION: %s\n" % pkg_dic[pkg]["PV"])
|
license_file.write("PACKAGE VERSION: %s\n" % pkg_dic[pkg]["PV"])
|
||||||
license_file.write("RECIPE NAME: %s\n" % pkg_dic[pkg]["PN"])
|
license_file.write("RECIPE NAME: %s\n" % pkg_dic[pkg]["PN"])
|
||||||
@@ -63,9 +79,7 @@ python license_create_manifest() {
|
|||||||
if pkg_dic[pkg]["PKGSIZE_%s" % pkg] == "0":
|
if pkg_dic[pkg]["PKGSIZE_%s" % pkg] == "0":
|
||||||
continue
|
continue
|
||||||
|
|
||||||
licenses = re.sub('[|&()*]', '', pkg_dic[pkg]["LICENSE"])
|
for lic in pkg_dic[pkg]["LICENSES"]:
|
||||||
licenses = re.sub(' *', ' ', licenses)
|
|
||||||
for lic in licenses.split():
|
|
||||||
lic_file = os.path.join(d.getVar('LICENSE_DIRECTORY', True),
|
lic_file = os.path.join(d.getVar('LICENSE_DIRECTORY', True),
|
||||||
pkg_dic[pkg]["PN"], "generic_%s" %
|
pkg_dic[pkg]["PN"], "generic_%s" %
|
||||||
re.sub('\+', '', lic))
|
re.sub('\+', '', lic))
|
||||||
@@ -101,11 +115,20 @@ python license_create_manifest() {
|
|||||||
pkg_rootfs_license = os.path.join(pkg_rootfs_license_dir, lic)
|
pkg_rootfs_license = os.path.join(pkg_rootfs_license_dir, lic)
|
||||||
|
|
||||||
if re.match("^generic_.*$", lic):
|
if re.match("^generic_.*$", lic):
|
||||||
|
generic_lic = re.search("^generic_(.*)$", lic).group(1)
|
||||||
|
if oe.license.license_ok(canonical_license(d,
|
||||||
|
generic_lic), bad_licenses) == False:
|
||||||
|
continue
|
||||||
|
|
||||||
if not os.path.exists(rootfs_license):
|
if not os.path.exists(rootfs_license):
|
||||||
os.link(pkg_license, rootfs_license)
|
os.link(pkg_license, rootfs_license)
|
||||||
|
|
||||||
os.symlink(os.path.join('..', lic), pkg_rootfs_license)
|
os.symlink(os.path.join('..', lic), pkg_rootfs_license)
|
||||||
else:
|
else:
|
||||||
|
if oe.license.license_ok(canonical_license(d,
|
||||||
|
lic), bad_licenses) == False:
|
||||||
|
continue
|
||||||
|
|
||||||
os.link(pkg_license, pkg_rootfs_license)
|
os.link(pkg_license, pkg_rootfs_license)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -138,3 +138,80 @@ def is_included(licensestr, whitelist=None, blacklist=None):
|
|||||||
return False, excluded
|
return False, excluded
|
||||||
else:
|
else:
|
||||||
return True, included
|
return True, included
|
||||||
|
|
||||||
|
class ManifestVisitor(LicenseVisitor):
|
||||||
|
"""Walk license tree (parsed from a string) removing the incompatible
|
||||||
|
licenses specified"""
|
||||||
|
def __init__(self, dont_want_licenses, canonical_license, d):
|
||||||
|
self._dont_want_licenses = dont_want_licenses
|
||||||
|
self._canonical_license = canonical_license
|
||||||
|
self._d = d
|
||||||
|
self._operators = []
|
||||||
|
|
||||||
|
self.licenses = []
|
||||||
|
self.licensestr = ''
|
||||||
|
|
||||||
|
LicenseVisitor.__init__(self)
|
||||||
|
|
||||||
|
def visit(self, node):
|
||||||
|
if isinstance(node, ast.Str):
|
||||||
|
lic = node.s
|
||||||
|
|
||||||
|
if license_ok(self._canonical_license(self._d, lic),
|
||||||
|
self._dont_want_licenses) == True:
|
||||||
|
if self._operators:
|
||||||
|
ops = []
|
||||||
|
for op in self._operators:
|
||||||
|
if op == '[':
|
||||||
|
ops.append(op)
|
||||||
|
elif op == ']':
|
||||||
|
ops.append(op)
|
||||||
|
else:
|
||||||
|
if not ops:
|
||||||
|
ops.append(op)
|
||||||
|
elif ops[-1] in ['[', ']']:
|
||||||
|
ops.append(op)
|
||||||
|
else:
|
||||||
|
ops[-1] = op
|
||||||
|
|
||||||
|
for op in ops:
|
||||||
|
if op == '[' or op == ']':
|
||||||
|
self.licensestr += op
|
||||||
|
elif self.licenses:
|
||||||
|
self.licensestr += ' ' + op + ' '
|
||||||
|
|
||||||
|
self._operators = []
|
||||||
|
|
||||||
|
self.licensestr += lic
|
||||||
|
self.licenses.append(lic)
|
||||||
|
elif isinstance(node, ast.BitAnd):
|
||||||
|
self._operators.append("&")
|
||||||
|
elif isinstance(node, ast.BitOr):
|
||||||
|
self._operators.append("|")
|
||||||
|
elif isinstance(node, ast.List):
|
||||||
|
self._operators.append("[")
|
||||||
|
elif isinstance(node, ast.Load):
|
||||||
|
self.licensestr += "]"
|
||||||
|
|
||||||
|
self.generic_visit(node)
|
||||||
|
|
||||||
|
def manifest_licenses(licensestr, dont_want_licenses, canonical_license, d):
|
||||||
|
"""Given a license string and dont_want_licenses list,
|
||||||
|
return license string filtered and a list of licenses"""
|
||||||
|
manifest = ManifestVisitor(dont_want_licenses, canonical_license, d)
|
||||||
|
|
||||||
|
try:
|
||||||
|
elements = manifest.get_elements(licensestr)
|
||||||
|
|
||||||
|
# Replace '()' to '[]' for handle in ast as List and Load types.
|
||||||
|
elements = ['[' if e == '(' else e for e in elements]
|
||||||
|
elements = [']' if e == ')' else e for e in elements]
|
||||||
|
|
||||||
|
manifest.visit_elements(elements)
|
||||||
|
except SyntaxError as exc:
|
||||||
|
raise LicenseSyntaxError(licensestr, exc)
|
||||||
|
|
||||||
|
# Replace '[]' to '()' for output correct license.
|
||||||
|
manifest.licensestr = manifest.licensestr.replace('[', '(').replace(']', ')')
|
||||||
|
|
||||||
|
return (manifest.licensestr, manifest.licenses)
|
||||||
|
|||||||
Reference in New Issue
Block a user