diff options
author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2013-05-03 14:21:59 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-05-03 16:12:54 +0100 |
commit | 4e39c1b9dbba1d2b07ffc2c6a1a252fc8f7680ee (patch) | |
tree | 61ae8a5673b86cff32896d0372f57bc74c2b653e /meta/classes/image.bbclass | |
parent | 2f954a9a6932f1e6c564e7e7aacaac628a75eed7 (diff) | |
download | openembedded-core-4e39c1b9dbba1d2b07ffc2c6a1a252fc8f7680ee.tar.gz openembedded-core-4e39c1b9dbba1d2b07ffc2c6a1a252fc8f7680ee.tar.bz2 openembedded-core-4e39c1b9dbba1d2b07ffc2c6a1a252fc8f7680ee.zip |
classes/image: allow complementary package globs to be extended
Make it easy for the wildcard specifications for complementary package
features to be extended outside of image.bbclass. For example, to add a
new "foo-pkgs" item that could be added to IMAGE_FEATURES that would
cause *-foo packages to be installed for all packages currently in the
image, you can now use this line at the global level:
COMPLEMENTARY_GLOB[foo-pkgs] = "*-foo"
Implements [YOCTO #4228].
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/image.bbclass')
-rw-r--r-- | meta/classes/image.bbclass | 23 |
1 files changed, 11 insertions, 12 deletions
diff --git a/meta/classes/image.bbclass b/meta/classes/image.bbclass index ffb372aebb..5bc0ca2d66 100644 --- a/meta/classes/image.bbclass +++ b/meta/classes/image.bbclass @@ -33,7 +33,7 @@ NORMAL_FEATURE_INSTALL_OPTIONAL = "${@' '.join(oe.packagegroup.optional_packages def normal_groups(d): """Return all the IMAGE_FEATURES, with the exception of our special package groups""" - extras = set(['dev-pkgs', 'staticdev-pkgs', 'doc-pkgs', 'dbg-pkgs', 'ptest-pkgs']) + extras = set(d.getVarFlags('COMPLEMENTARY_GLOB').keys()) features = set(oe.data.typed_value('IMAGE_FEATURES', d)) return features.difference(extras) @@ -43,20 +43,19 @@ PACKAGE_GROUP_splash = "${SPLASH}" # Wildcards specifying complementary packages to install for every package that has been explicitly # installed into the rootfs +COMPLEMENTARY_GLOB[dev-pkgs] = '*-dev' +COMPLEMENTARY_GLOB[staticdev-pkgs] = '*-staticdev' +COMPLEMENTARY_GLOB[doc-pkgs] = '*-doc' +COMPLEMENTARY_GLOB[dbg-pkgs] = '*-dbg' +COMPLEMENTARY_GLOB[ptest-pkgs] = '*-ptest' + def complementary_globs(featurevar, d): + all_globs = d.getVarFlags('COMPLEMENTARY_GLOB') globs = [] features = set((d.getVar(featurevar, True) or '').split()) - for feature in features: - if feature == 'dev-pkgs': - globs.append('*-dev') - elif feature == 'staticdev-pkgs': - globs.append('*-staticdev') - elif feature == 'doc-pkgs': - globs.append('*-doc') - elif feature == 'dbg-pkgs': - globs.append('*-dbg') - elif feature == 'ptest-pkgs': - globs.append('*-ptest') + for name, glob in all_globs.items(): + if name in features: + globs.append(glob) return ' '.join(globs) IMAGE_INSTALL_COMPLEMENTARY = '${@complementary_globs("IMAGE_FEATURES", d)}' |