summaryrefslogtreecommitdiff
path: root/bitbake-dev/lib/bb/parse
diff options
context:
space:
mode:
authorRichard Purdie <rpurdie@linux.intel.com>2009-01-03 16:33:11 +0000
committerRichard Purdie <rpurdie@linux.intel.com>2009-01-03 16:33:11 +0000
commit772ec7db089f5fefd85e1e37695a22009e76d3bc (patch)
tree4f3f9066803f61b1f1898c1d39dff4f800239b40 /bitbake-dev/lib/bb/parse
parentee0faf1346cabb0c90f43891ede3f88878f87b8b (diff)
downloadopenembedded-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.py17
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)