summaryrefslogtreecommitdiffstats
path: root/bitbake/lib/bb/data.py
diff options
context:
space:
mode:
authorMarkus Lehtonen <markus.lehtonen@linux.intel.com>2016-11-01 17:05:11 +0200
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-11-04 12:50:55 +0000
commitc5f609edbf64da9d7d32be057f1b6b824f749d6c (patch)
tree08dfddf4c62c1a876ef7cfb6c709d41fe1b12137 /bitbake/lib/bb/data.py
parent589f08aa852dd43af5d05d698cfa917bec084210 (diff)
downloadpoky-c5f609edbf64da9d7d32be057f1b6b824f749d6c.tar.gz
bitbake: data: fix exception handling in exported_vars()
Fix a bug where a totally wrong value of a variable would be exported if an exception happened during d.getVar(). Also, print a warning if an exception happends instead of silently ignoring it. It would probably be best just to raise the exception, instead, but use the warning for now in order to avoid breaking existing builds. [YOCTO #10393] (Bitbake rev: f639f06cfa280adcc25438387567966271b9b2c3) Signed-off-by: Markus Lehtonen <markus.lehtonen@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/bb/data.py')
-rw-r--r--bitbake/lib/bb/data.py8
1 files changed, 5 insertions, 3 deletions
diff --git a/bitbake/lib/bb/data.py b/bitbake/lib/bb/data.py
index c1f27cd0c3..c56965c602 100644
--- a/bitbake/lib/bb/data.py
+++ b/bitbake/lib/bb/data.py
@@ -258,11 +258,13 @@ def exported_keys(d):
258 not d.getVarFlag(key, 'unexport', False)) 258 not d.getVarFlag(key, 'unexport', False))
259 259
260def exported_vars(d): 260def exported_vars(d):
261 for key in exported_keys(d): 261 k = list(exported_keys(d))
262 for key in k:
262 try: 263 try:
263 value = d.getVar(key, True) 264 value = d.getVar(key, True)
264 except Exception: 265 except Exception as err:
265 pass 266 bb.warn("%s: Unable to export ${%s}: %s" % (d.getVar("FILE", True), key, err))
267 continue
266 268
267 if value is not None: 269 if value is not None:
268 yield key, str(value) 270 yield key, str(value)