diff options
author | Richard Purdie <rpurdie@linux.intel.com> | 2009-01-03 16:33:11 +0000 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2009-01-03 16:33:11 +0000 |
commit | 772ec7db089f5fefd85e1e37695a22009e76d3bc (patch) | |
tree | 4f3f9066803f61b1f1898c1d39dff4f800239b40 /bitbake-dev/lib/bb/parse | |
parent | ee0faf1346cabb0c90f43891ede3f88878f87b8b (diff) | |
download | openembedded-core-772ec7db089f5fefd85e1e37695a22009e76d3bc.tar.gz openembedded-core-772ec7db089f5fefd85e1e37695a22009e76d3bc.tar.bz2 openembedded-core-772ec7db089f5fefd85e1e37695a22009e76d3bc.zip |
bitbake-dev: Add BBCLASSEXTEND support
Diffstat (limited to 'bitbake-dev/lib/bb/parse')
-rw-r--r-- | bitbake-dev/lib/bb/parse/parse_py/BBHandler.py | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/bitbake-dev/lib/bb/parse/parse_py/BBHandler.py b/bitbake-dev/lib/bb/parse/parse_py/BBHandler.py index 00ad6ef4fe..5a128e8673 100644 --- a/bitbake-dev/lib/bb/parse/parse_py/BBHandler.py +++ b/bitbake-dev/lib/bb/parse/parse_py/BBHandler.py @@ -181,8 +181,21 @@ def handle(fn, d, include = 0): classes.remove(__classname__) else: if include == 0: - finalise(fn, d) - + multi = data.getVar('BBCLASSEXTEND', d, 1) + if multi: + based = bb.data.createCopy(d) + finalise(fn, based) + darray = {"": based} + for cls in multi.split(): + pn = data.getVar('PN', d, True) + based = bb.data.createCopy(d) + data.setVar('PN', pn + '-' + cls, based) + inherit([cls], based) + finalise(fn, based) + darray[cls] = based + return darray + else: + finalise(fn, d) bbpath.pop(0) if oldfile: bb.data.setVar("FILE", oldfile, d) |