summaryrefslogtreecommitdiffstats
path: root/meta/classes/multilib.bbclass
diff options
context:
space:
mode:
Diffstat (limited to 'meta/classes/multilib.bbclass')
-rw-r--r--meta/classes/multilib.bbclass31
1 files changed, 31 insertions, 0 deletions
diff --git a/meta/classes/multilib.bbclass b/meta/classes/multilib.bbclass
index c2d2f85a12..f3e7618c95 100644
--- a/meta/classes/multilib.bbclass
+++ b/meta/classes/multilib.bbclass
@@ -66,3 +66,34 @@ python __anonymous () {
66 clsextend.map_variable("PACKAGE_INSTALL") 66 clsextend.map_variable("PACKAGE_INSTALL")
67 clsextend.map_variable("INITSCRIPT_PACKAGES") 67 clsextend.map_variable("INITSCRIPT_PACKAGES")
68} 68}
69
70PACKAGEFUNCS_append = "do_package_qa_multilib"
71
72python do_package_qa_multilib() {
73
74 def check_mlprefix(pkg, var, mlprefix):
75 values = bb.utils.explode_dep_versions(d.getVar('%s_%s' % (var, pkg), True) or d.getVar(var, True) or "")
76 candidates = []
77 for i in values.keys():
78 if i.startswith('virtual/'):
79 i = i[len('virtual/'):]
80 if (not i.startswith('kernel-module')) and (not i.startswith(mlprefix)):
81 candidates.append(i)
82 if len(candidates) > 0:
83 bb.warn("Multilib QA Issue: %s package %s - suspicious values '%s' in %s"
84 % (d.getVar('PN', True), pkg, ' '.join(candidates), var))
85
86 ml = d.getVar('MLPREFIX', True)
87 if not ml:
88 return
89
90 packages = d.getVar('PACKAGES', True)
91 for pkg in packages.split():
92 check_mlprefix(pkg, 'RDEPENDS', ml)
93 check_mlprefix(pkg, 'RPROVIDES', ml)
94 check_mlprefix(pkg, 'RRECOMMENDS', ml)
95 check_mlprefix(pkg, 'RSUGGESTS', ml)
96 check_mlprefix(pkg, 'RREPLACES', ml)
97 check_mlprefix(pkg, 'RCONFLICTS', ml)
98}
99