summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--meta/classes/features_check.bbclass15
1 files changed, 15 insertions, 0 deletions
diff --git a/meta/classes/features_check.bbclass b/meta/classes/features_check.bbclass
index 4ba827d4ab..b3c8047861 100644
--- a/meta/classes/features_check.bbclass
+++ b/meta/classes/features_check.bbclass
@@ -16,7 +16,19 @@ python () {
16 if d.getVar('PARSE_ALL_RECIPES', False): 16 if d.getVar('PARSE_ALL_RECIPES', False):
17 return 17 return
18 18
19 unused = True
20
19 for kind in ['DISTRO', 'MACHINE', 'COMBINED']: 21 for kind in ['DISTRO', 'MACHINE', 'COMBINED']:
22 if d.getVar('ANY_OF_' + kind + '_FEATURES') is None and \
23 d.overridedata.get('ANY_OF_' + kind + '_FEATURES') is None and \
24 d.getVar('REQUIRED_' + kind + '_FEATURES') is None and \
25 d.overridedata.get('REQUIRED_' + kind + '_FEATURES') is None and \
26 d.getVar('CONFLICT_' + kind + '_FEATURES') is None and \
27 d.overridedata.get('CONFLICT_' + kind + '_FEATURES') is None:
28 continue
29
30 unused = False
31
20 # Assume at least one var is set. 32 # Assume at least one var is set.
21 features = set((d.getVar(kind + '_FEATURES') or '').split()) 33 features = set((d.getVar(kind + '_FEATURES') or '').split())
22 34
@@ -39,4 +51,7 @@ python () {
39 if conflicts: 51 if conflicts:
40 raise bb.parse.SkipRecipe("conflicting %s feature%s '%s' (in %s_FEATURES)" 52 raise bb.parse.SkipRecipe("conflicting %s feature%s '%s' (in %s_FEATURES)"
41 % (kind.lower(), 's' if len(conflicts) > 1 else '', ' '.join(conflicts), kind)) 53 % (kind.lower(), 's' if len(conflicts) > 1 else '', ' '.join(conflicts), kind))
54
55 if unused:
56 bb.warn("Recipe inherits features_check but doesn't use it")
42} 57}