diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-01-21 22:49:50 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-01-24 20:07:59 +0000 |
commit | 6f817779af77fdb0b861297f0f43c4c6607ce6f0 (patch) | |
tree | 2ffbc72ca355ac44ab5f3cd312a98aa1b5f1bf85 /meta/classes/packagedata.bbclass | |
parent | 1a60e96b21d328fe936e594f3061459e8f2f1b5e (diff) | |
download | openembedded-core-contrib-6f817779af77fdb0b861297f0f43c4c6607ce6f0.tar.gz |
packagedata: Add error message if multiple recipes try to write the same package
If multiple recipes try and write the same package it resulted in a
rather confusing traceback and unintuitive error. This patch
prints a human readable error instead.
[YOCTO #3645]
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/packagedata.bbclass')
-rw-r--r-- | meta/classes/packagedata.bbclass | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/meta/classes/packagedata.bbclass b/meta/classes/packagedata.bbclass index 790d874c1cb..120cd6445fb 100644 --- a/meta/classes/packagedata.bbclass +++ b/meta/classes/packagedata.bbclass @@ -1,7 +1,8 @@ python read_subpackage_metadata () { import oe.packagedata - data = oe.packagedata.read_pkgdata(d.getVar('PN', True), d) + pn = d.getVar('PN', True) + data = oe.packagedata.read_pkgdata(pn, d) for key in data.keys(): d.setVar(key, data[key]) @@ -9,5 +10,9 @@ python read_subpackage_metadata () { for pkg in d.getVar('PACKAGES', True).split(): sdata = oe.packagedata.read_subpkgdata(pkg, d) for key in sdata.keys(): + if key == "PN": + if sdata[key] != pn: + bb.fatal("Recipe %s is trying to create package %s which was already written by recipe %s. This will cause corruption, please resolve this and only provide the package from one recipe or the other or only build one of the recipes." % (pn, pkg, sdata[key])) + continue d.setVar(key, sdata[key]) } |