summaryrefslogtreecommitdiff
path: root/bitbake/lib/bb
diff options
context:
space:
mode:
Diffstat (limited to 'bitbake/lib/bb')
-rw-r--r--bitbake/lib/bb/utils.py17
1 files changed, 10 insertions, 7 deletions
diff --git a/bitbake/lib/bb/utils.py b/bitbake/lib/bb/utils.py
index 569aa6a8c..1778a1e2e 100644
--- a/bitbake/lib/bb/utils.py
+++ b/bitbake/lib/bb/utils.py
@@ -310,13 +310,16 @@ def better_compile(text, file, realfile, mode = "exec"):
# split the text into lines again
body = text.split('\n')
bb.msg.error(bb.msg.domain.Util, "Error in compiling python function in: %s" % (realfile))
- bb.msg.error(bb.msg.domain.Util, "The lines leading to this error were:")
- bb.msg.error(bb.msg.domain.Util, "\t%d:%s:'%s'" % (e.lineno, e.__class__.__name__, body[e.lineno-1]))
-
- _print_trace(body, e.lineno)
-
- # exit now
- sys.exit(1)
+ bb.msg.error(bb.msg.domain.Util, str(e))
+ if e.lineno:
+ bb.msg.error(bb.msg.domain.Util, "The lines leading to this error were:")
+ bb.msg.error(bb.msg.domain.Util, "\t%d:%s:'%s'" % (e.lineno, e.__class__.__name__, body[e.lineno-1]))
+ _print_trace(body, e.lineno)
+ else:
+ bb.msg.error(bb.msg.domain.Util, "The function causing this error was:")
+ for line in body:
+ bb.msg.error(bb.msg.domain.Util, line)
+ raise
def better_exec(code, context, text, realfile):
"""