From 6e3a3816d5ba4b074f3c119437660fc72efe9fdc Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Thu, 19 Aug 2010 23:26:46 +0100 Subject: bitbake/utils.py: Give useful debug information when no lineno information is available Signed-off-by: Richard Purdie --- bitbake/lib/bb/utils.py | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) (limited to 'bitbake') 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): """ -- cgit v1.2.3