summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2013-01-21 22:49:50 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2013-01-24 20:09:00 +0000
commit1f8f6fe4eb6884ac3a254d4ef54c7841e407ecab (patch)
treee47096dcdcf724e9821cecb773aa3131e181c0c8
parent932a4cdf4ba4368a2f9e066ed086d08a449f92ec (diff)
downloadpoky-1f8f6fe4eb6884ac3a254d4ef54c7841e407ecab.tar.gz
poky-1f8f6fe4eb6884ac3a254d4ef54c7841e407ecab.tar.bz2
poky-1f8f6fe4eb6884ac3a254d4ef54c7841e407ecab.zip
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] (From OE-Core rev: 6f817779af77fdb0b861297f0f43c4c6607ce6f0) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--meta/classes/packagedata.bbclass7
1 files changed, 6 insertions, 1 deletions
diff --git a/meta/classes/packagedata.bbclass b/meta/classes/packagedata.bbclass
index 790d874c1c..120cd6445f 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])
}