Files
poky/meta/classes/features_check.bbclass
Jacob Kroon 3c5f798c5f features_check: Factorize code for checking features
The DISTRO/MACHINE/COMBINED features should be treated identically, so
convert the expanded code to a loop. This fixes some of the COMBINED error
messages which were previously referring to MACHINE features. There
should be no functional changes.

(From OE-Core rev: 051f6efd1b2d5c8c11ab91a75a34f6dc04caf211)

Signed-off-by: Jacob Kroon <jacob.kroon@gmail.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2020-06-09 13:13:59 +01:00

43 lines
1.9 KiB
Plaintext

# Allow checking of required and conflicting features
#
# xxx = [DISTRO,MACHINE,COMBINED]
#
# ANY_OF_xxx_FEATURES: ensure at least one item on this list is included
# in xxx_FEATURES.
# REQUIRED_xxx_FEATURES: ensure every item on this list is included
# in xxx_FEATURES.
# CONFLICT_xxx_FEATURES: ensure no item in this list is included in
# xxx_FEATURES.
#
# Copyright 2019 (C) Texas Instruments Inc.
# Copyright 2013 (C) O.S. Systems Software LTDA.
python () {
if d.getVar('PARSE_ALL_RECIPES', False):
return
for kind in ['DISTRO', 'MACHINE', 'COMBINED']:
# Assume at least one var is set.
features = set((d.getVar(kind + '_FEATURES') or '').split())
any_of_features = set((d.getVar('ANY_OF_' + kind + '_FEATURES') or '').split())
if any_of_features:
if set.isdisjoint(any_of_features, features):
raise bb.parse.SkipRecipe("one of '%s' needs to be in %s_FEATURES"
% (' '.join(any_of_features), kind))
required_features = set((d.getVar('REQUIRED_' + kind + '_FEATURES') or '').split())
if required_features:
missing = set.difference(required_features, features)
if missing:
raise bb.parse.SkipRecipe("missing required %s feature%s '%s' (not in %s_FEATURES)"
% (kind.lower(), 's' if len(missing) > 1 else '', ' '.join(missing), kind))
conflict_features = set((d.getVar('CONFLICT_' + kind + '_FEATURES') or '').split())
if conflict_features:
conflicts = set.intersection(conflict_features, features)
if conflicts:
raise bb.parse.SkipRecipe("conflicting %s feature%s '%s' (in %s_FEATURES)"
% (kind.lower(), 's' if len(conflicts) > 1 else '', ' '.join(conflicts), kind))
}