> -----Original Message-----
> From: [email protected]
> <[email protected]> On Behalf Of Richard Purdie
> Sent: den 2 mars 2022 00:42
> To: [email protected]
> Subject: [OE-core] [PATCH 3/4] license/insane: Show warning for obsolete
> license usage
>
> We want to use SPDX identifiers in LICENSE variables. There is now a
> conversion script to make most of the translations. Add a list of
> strings which have been replaced so we can show warnings to users
> if they're still used anywhere.
>
> Add checks to the package as insane check. This is currently a warning
> by default but can be turned off or made an error as per the other standard
> checks.
>
> Signed-off-by: Richard Purdie <[email protected]>
> ---
> meta/classes/base.bbclass | 6 ++++++
> meta/classes/insane.bbclass | 31 ++++++++++++++++++++++---------
> meta/lib/oe/license.py | 10 ++++++++++
> 3 files changed, 38 insertions(+), 9 deletions(-)
>
> diff --git a/meta/classes/base.bbclass b/meta/classes/base.bbclass
> index bfc7087a189..b7869da3b38 100644
> --- a/meta/classes/base.bbclass
> +++ b/meta/classes/base.bbclass
> @@ -597,6 +597,12 @@ python () {
>
> exceptions = (d.getVar("INCOMPATIBLE_LICENSE_EXCEPTIONS") or
> "").split()
>
> + for lic_exception in exceptions:
> + if ":" in lic_exception:
> + lic_exception.split(":")[0]
> + if lic_exception in oe.license.obsolete_license_list():
> + bb.fatal("Invalid license %s used in
> INCOMPATIBLE_LICENSE_EXCEPTIONS" % lic_exception)
> +
> pkgs = d.getVar('PACKAGES').split()
> skipped_pkgs = {}
> unskipped_pkgs = []
> diff --git a/meta/classes/insane.bbclass b/meta/classes/insane.bbclass
> index 29b9b3d466a..3c8d49f13bd 100644
> --- a/meta/classes/insane.bbclass
> +++ b/meta/classes/insane.bbclass
> @@ -27,7 +27,7 @@ WARN_QA ?= " libdir xorg-driver-abi \
> mime mime-xdg unlisted-pkg-lics unhandled-features-check \
> missing-update-alternatives native-last missing-ptest \
> license-exists license-no-generic license-syntax license-format \
> - license-incompatible license-file-missing \
> + license-incompatible license-file-missing obsolete-license \
> "
> ERROR_QA ?= "dev-so debug-deps dev-deps debug-files arch pkgconfig la \
> perms dep-cmp pkgvarcheck perm-config perm-line perm-link \
> @@ -909,14 +909,19 @@ def package_qa_check_unlisted_pkg_lics(package, d,
> messages):
> return True
>
> recipe_lics_set = oe.license.list_licenses(d.getVar('LICENSE'))
> - unlisted = oe.license.list_licenses(pkg_lics) - recipe_lics_set
> - if not unlisted:
> - return True
> -
> - oe.qa.add_message(messages, "unlisted-pkg-lics",
> - "LICENSE:%s includes licenses (%s) that are not "
> - "listed in LICENSE" % (package, '
> '.join(unlisted)))
> - return False
> + package_lics = oe.license.list_licenses(pkg_lics)
> + unlisted = package_lics - recipe_lics_set
> + if unlisted:
> + oe.qa.add_message(messages, "unlisted-pkg-lics",
> + "LICENSE:%s includes licenses (%s) that are
> not "
> + "listed in LICENSE" % (package, '
> '.join(unlisted)))
> + return False
> + obsolete = set(oe.license.obsolete_license_list()) & package_lics -
> recipe_lics_set
> + if obsolete:
> + oe.qa.add_message(messages, "obsolete-license",
> + "LICENSE:%s includes obsolete licenses %s" %
> (package, ' '.join(obsolete)))
> + return False
> + return True
>
> QAPKGTEST[empty-dirs] = "package_qa_check_empty_dirs"
> def package_qa_check_empty_dirs(pkg, d, messages):
> @@ -1012,6 +1017,14 @@ python do_package_qa () {
>
> bb.note("DO PACKAGE QA")
>
> + main_lic = d.getVar('LICENSE')
> +
> + # Check for obsolete license references in main LICENSE (packages are
> checked below for any changes)
> + main_licenses = oe.license.list_licenses(d.getVar('LICENSE'))
The documentation for oe.license.list_licenses() says that it returns
a list, but I assume that is not true or the code below would not work...
> + obsolete = set(oe.license.obsolete_license_list()) & main_licenses
> + if obsolete:
> + oe.qa.handle_error("obsolete-license", "Recipe LICENSE includes
> obsolete licenses %s" % ' '.join(obsolete), d)
> +
> bb.build.exec_func("read_subpackage_metadata", d)
>
> # Check non UTF-8 characters on recipe's metadata
//Peter
-=-=-=-=-=-=-=-=-=-=-=-
Links: You receive all messages sent to this group.
View/Reply Online (#162615):
https://lists.openembedded.org/g/openembedded-core/message/162615
Mute This Topic: https://lists.openembedded.org/mt/89490745/21656
Group Owner: [email protected]
Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub
[[email protected]]
-=-=-=-=-=-=-=-=-=-=-=-