summaryrefslogtreecommitdiff
path: root/yocto-poky/meta/classes/distro_features_check.bbclass
diff options
context:
space:
mode:
authorPatrick Williams <patrick@stwcx.xyz>2015-09-15 22:41:29 +0300
committerPatrick Williams <patrick@stwcx.xyz>2015-09-15 22:41:29 +0300
commit21f9b84b4b729fbd7acbd465e7a3f726e4d20f91 (patch)
treeeb2d091d427ca0813b445509d59cc8e27e8ad25f /yocto-poky/meta/classes/distro_features_check.bbclass
parent101cef31e2bf54c678501155cd2106251acbd076 (diff)
parentc124f4f2e04dca16a428a76c89677328bc7bf908 (diff)
downloadopenbmc-21f9b84b4b729fbd7acbd465e7a3f726e4d20f91.tar.xz
Merge commit 'c124f4f2e04dca16a428a76c89677328bc7bf908' as 'yocto-poky'
Diffstat (limited to 'yocto-poky/meta/classes/distro_features_check.bbclass')
-rw-r--r--yocto-poky/meta/classes/distro_features_check.bbclass37
1 files changed, 37 insertions, 0 deletions
diff --git a/yocto-poky/meta/classes/distro_features_check.bbclass b/yocto-poky/meta/classes/distro_features_check.bbclass
new file mode 100644
index 000000000..7e91dbcf4
--- /dev/null
+++ b/yocto-poky/meta/classes/distro_features_check.bbclass
@@ -0,0 +1,37 @@
+# Allow checking of required and conflicting DISTRO_FEATURES
+#
+# ANY_OF_DISTRO_FEATURES: ensure at least one item on this list is included
+# in DISTRO_FEATURES.
+# REQUIRED_DISTRO_FEATURES: ensure every item on this list is included
+# in DISTRO_FEATURES.
+# CONFLICT_DISTRO_FEATURES: ensure no item in this list is included in
+# DISTRO_FEATURES.
+#
+# Copyright 2013 (C) O.S. Systems Software LTDA.
+
+python () {
+ # Assume at least one var is set.
+ distro_features = (d.getVar('DISTRO_FEATURES', True) or "").split()
+
+ any_of_distro_features = d.getVar('ANY_OF_DISTRO_FEATURES', True)
+ if any_of_distro_features:
+ any_of_distro_features = any_of_distro_features.split()
+ if set.isdisjoint(set(any_of_distro_features),set(distro_features)):
+ raise bb.parse.SkipPackage("one of '%s' needs to be in DISTRO_FEATURES" % any_of_distro_features)
+
+ required_distro_features = d.getVar('REQUIRED_DISTRO_FEATURES', True)
+ if required_distro_features:
+ required_distro_features = required_distro_features.split()
+ for f in required_distro_features:
+ if f in distro_features:
+ continue
+ else:
+ raise bb.parse.SkipPackage("missing required distro feature '%s' (not in DISTRO_FEATURES)" % f)
+
+ conflict_distro_features = d.getVar('CONFLICT_DISTRO_FEATURES', True)
+ if conflict_distro_features:
+ conflict_distro_features = conflict_distro_features.split()
+ for f in conflict_distro_features:
+ if f in distro_features:
+ raise bb.parse.SkipPackage("conflicting distro feature '%s' (in DISTRO_FEATURES)" % f)
+}