summaryrefslogtreecommitdiff
path: root/meta/classes/base.bbclass
diff options
context:
space:
mode:
authorPeter Seebach <peter.seebach@windriver.com>2012-08-10 17:32:56 -0500
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-08-15 14:25:50 +0100
commit9bc0ca9369d0daee94abf60d3d521cc734c7e8cd (patch)
treeb2f535674fccef7cd33b89e66037935ef4260b3c /meta/classes/base.bbclass
parentf3c93627d4f603f9e4c4491d89eb988aa6241662 (diff)
downloadopenembedded-core-9bc0ca9369d0daee94abf60d3d521cc734c7e8cd.tar.gz
openembedded-core-9bc0ca9369d0daee94abf60d3d521cc734c7e8cd.tar.bz2
openembedded-core-9bc0ca9369d0daee94abf60d3d521cc734c7e8cd.zip
base.bbclass: Expand PNBLACKLIST across multilibs too
The PNBLACKLIST feature does not currently work with multilibs, because they have different ${PN}. The obvious thing to do is to do this at the same point that we do the PREFERRED_PROVIDER and PREFERRED_VERSION fixups. (Making the PNBLACKLIST check do the for-each-multilib check requires it to do the multilib list generation repeatedly.) Signed-off-by: Peter Seebach <peter.seebach@windriver.com> Signed-off-by: Saul Wold <sgw@linux.intel.com>
Diffstat (limited to 'meta/classes/base.bbclass')
-rw-r--r--meta/classes/base.bbclass10
1 files changed, 9 insertions, 1 deletions
diff --git a/meta/classes/base.bbclass b/meta/classes/base.bbclass
index 192c77761e..840ddbcc93 100644
--- a/meta/classes/base.bbclass
+++ b/meta/classes/base.bbclass
@@ -161,7 +161,8 @@ def pkgarch_mapping(d):
def preferred_ml_updates(d):
# If any PREFERRED_PROVIDER or PREFERRED_VERSIONS are set,
- # we need to mirror these variables in the multilib case
+ # we need to mirror these variables in the multilib case;
+ # likewise the PNBLACKLIST flags.
multilibs = d.getVar('MULTILIBS', True) or ""
if not multilibs:
return
@@ -174,12 +175,19 @@ def preferred_ml_updates(d):
versions = []
providers = []
+ blacklists = d.getVarFlags('PNBLACKLIST') or []
for v in d.keys():
if v.startswith("PREFERRED_VERSION_"):
versions.append(v)
if v.startswith("PREFERRED_PROVIDER_"):
providers.append(v)
+ for pkg, reason in blacklists.items():
+ for p in prefixes:
+ newpkg = p + "-" + pkg
+ if not d.getVarFlag('PNBLACKLIST', newpkg, True):
+ d.setVarFlag('PNBLACKLIST', newpkg, reason)
+
for v in versions:
val = d.getVar(v, False)
pkg = v.replace("PREFERRED_VERSION_", "")