diff options
author | Chris Larson <chris_larson@mentor.com> | 2010-10-08 20:05:06 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-05-20 17:41:03 +0100 |
commit | 4df212e9c2a1dd7c80d180fd13b67e9f2799d3e1 (patch) | |
tree | 1639f0c0f38e5f497a2169c40574b55b9e414d03 /meta/lib | |
parent | e02c0d809732bed3d170880c6faedafce8c60c21 (diff) | |
download | openembedded-core-4df212e9c2a1dd7c80d180fd13b67e9f2799d3e1.tar.gz openembedded-core-4df212e9c2a1dd7c80d180fd13b67e9f2799d3e1.tar.bz2 openembedded-core-4df212e9c2a1dd7c80d180fd13b67e9f2799d3e1.tar.xz openembedded-core-4df212e9c2a1dd7c80d180fd13b67e9f2799d3e1.zip |
oe.packagegroup: add code for package groups (sync from OE)
This includes some utility functions for dealing with groups of packages
defined in the metadata. Metadata syntax:
PACKAGE_GROUP_<group> = "<list of packages>"
If the packages in the group are optional:
PACKAGE_GROUP_<group>[optional] = "1"
Signed-off-by: Chris Larson <chris_larson@mentor.com>
Diffstat (limited to 'meta/lib')
-rw-r--r-- | meta/lib/oe/packagegroup.py | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/meta/lib/oe/packagegroup.py b/meta/lib/oe/packagegroup.py new file mode 100644 index 000000000..b04c45a1a --- /dev/null +++ b/meta/lib/oe/packagegroup.py @@ -0,0 +1,29 @@ +import itertools + +def is_optional(group, d): + return bool(d.getVarFlag("PACKAGE_GROUP_%s" % group, "optional")) + +def packages(groups, d): + for group in groups: + for pkg in (d.getVar("PACKAGE_GROUP_%s" % group, True) or "").split(): + yield pkg + +def required_packages(groups, d): + req = filter(lambda group: not is_optional(group, d), groups) + return packages(req, d) + +def optional_packages(groups, d): + opt = filter(lambda group: is_optional(group, d), groups) + return packages(opt, d) + +def active_packages(features, d): + return itertools.chain(required_packages(features, d), + optional_packages(features, d)) + +def active_recipes(features, d): + import oe.packagedata + + for pkg in active_packages(features, d): + recipe = oe.packagedata.recipename(pkg, d) + if recipe: + yield recipe |