diff options
Diffstat (limited to 'bitbake/lib/bb')
-rw-r--r-- | bitbake/lib/bb/exceptions.py | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/bitbake/lib/bb/exceptions.py b/bitbake/lib/bb/exceptions.py index 86621d24ba..62d62cd4d8 100644 --- a/bitbake/lib/bb/exceptions.py +++ b/bitbake/lib/bb/exceptions.py | |||
@@ -29,13 +29,30 @@ class TracebackEntry(namedtuple.abc): | |||
29 | def __str__(self): | 29 | def __str__(self): |
30 | return ''.join(self.format()) | 30 | return ''.join(self.format()) |
31 | 31 | ||
32 | def _get_frame_args(frame): | ||
33 | """Get the formatted arguments and class (if available) for a frame""" | ||
34 | arginfo = inspect.getargvalues(frame) | ||
35 | firstarg = arginfo.args[0] | ||
36 | if firstarg == 'self': | ||
37 | self = arginfo.locals['self'] | ||
38 | cls = self.__class__.__name__ | ||
39 | |||
40 | arginfo.args.pop(0) | ||
41 | del arginfo.locals['self'] | ||
42 | else: | ||
43 | cls = None | ||
44 | |||
45 | formatted = inspect.formatargvalues(*arginfo) | ||
46 | return formatted, cls | ||
32 | 47 | ||
33 | def extract_traceback(tb, context=1): | 48 | def extract_traceback(tb, context=1): |
34 | frames = inspect.getinnerframes(tb, context) | 49 | frames = inspect.getinnerframes(tb, context) |
35 | for frame, filename, lineno, function, code_context, index in frames: | 50 | for frame, filename, lineno, function, code_context, index in frames: |
36 | args = inspect.formatargvalues(*inspect.getargvalues(frame)) | 51 | formatted_args, cls = _get_frame_args(frame) |
37 | yield TracebackEntry(filename, lineno, function, args, code_context, index) | 52 | if cls: |
38 | 53 | function = '%s.%s' % (cls, function) | |
54 | yield TracebackEntry(filename, lineno, function, formatted_args, | ||
55 | code_context, index) | ||
39 | 56 | ||
40 | def format_extracted(extracted, formatter=None, limit=None): | 57 | def format_extracted(extracted, formatter=None, limit=None): |
41 | if limit: | 58 | if limit: |