OLD | NEW |
---|---|
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/bootstrap_natives.h" | 5 #include "vm/bootstrap_natives.h" |
6 #include "vm/exceptions.h" | 6 #include "vm/exceptions.h" |
7 #include "vm/object_store.h" | 7 #include "vm/object_store.h" |
8 #include "vm/runtime_entry.h" | 8 #include "vm/runtime_entry.h" |
9 #include "vm/stack_frame.h" | 9 #include "vm/stack_frame.h" |
10 | 10 |
11 namespace dart { | 11 namespace dart { |
12 | 12 |
13 static void IterateFrames(const GrowableObjectArray& code_list, | 13 static void IterateFrames(const GrowableObjectArray& code_list, |
14 const GrowableObjectArray& pc_offset_list) { | 14 const GrowableObjectArray& pc_offset_list, |
15 int skip_frames) { | |
15 StackFrameIterator frames(StackFrameIterator::kDontValidateFrames); | 16 StackFrameIterator frames(StackFrameIterator::kDontValidateFrames); |
16 StackFrame* frame = frames.NextFrame(); | 17 StackFrame* frame = frames.NextFrame(); |
17 ASSERT(frame != NULL); // We expect to find a dart invocation frame. | 18 ASSERT(frame != NULL); // We expect to find a dart invocation frame. |
18 Code& code = Code::Handle(); | 19 Code& code = Code::Handle(); |
19 Smi& offset = Smi::Handle(); | 20 Smi& offset = Smi::Handle(); |
20 while (frame != NULL) { | 21 while (frame != NULL) { |
21 if (frame->IsDartFrame()) { | 22 if (frame->IsDartFrame()) { |
22 code = frame->LookupDartCode(); | 23 if (skip_frames > 0) { |
23 offset = Smi::New(frame->pc() - code.EntryPoint()); | 24 skip_frames--; |
24 code_list.Add(code); | 25 } else { |
25 pc_offset_list.Add(offset); | 26 code = frame->LookupDartCode(); |
27 offset = Smi::New(frame->pc() - code.EntryPoint()); | |
28 code_list.Add(code); | |
29 pc_offset_list.Add(offset); | |
30 } | |
26 } | 31 } |
27 frame = frames.NextFrame(); | 32 frame = frames.NextFrame(); |
28 } | 33 } |
29 } | 34 } |
30 | 35 |
31 | 36 |
32 // An utility method for convenient printing of dart stack traces when | 37 // An utility method for convenient printing of dart stack traces when |
33 // inside 'gdb'. Note: This function will only work when there is a | 38 // inside 'gdb'. Note: This function will only work when there is a |
34 // valid exit frame information. It will not work when a breakpoint is | 39 // valid exit frame information. It will not work when a breakpoint is |
35 // set in dart code and control is got inside 'gdb' without going through | 40 // set in dart code and control is got inside 'gdb' without going through |
36 // the runtime or native transition stub. | 41 // the runtime or native transition stub. |
37 void _printCurrentStacktrace() { | 42 void _printCurrentStacktrace() { |
38 const GrowableObjectArray& code_list = | 43 const GrowableObjectArray& code_list = |
39 GrowableObjectArray::Handle(GrowableObjectArray::New()); | 44 GrowableObjectArray::Handle(GrowableObjectArray::New()); |
40 const GrowableObjectArray& pc_offset_list = | 45 const GrowableObjectArray& pc_offset_list = |
41 GrowableObjectArray::Handle(GrowableObjectArray::New()); | 46 GrowableObjectArray::Handle(GrowableObjectArray::New()); |
42 IterateFrames(code_list, pc_offset_list); | 47 IterateFrames(code_list, pc_offset_list, 0); |
43 const Array& code_array = Array::Handle(Array::MakeArray(code_list)); | 48 const Array& code_array = Array::Handle(Array::MakeArray(code_list)); |
44 const Array& pc_offset_array = | 49 const Array& pc_offset_array = |
45 Array::Handle(Array::MakeArray(pc_offset_list)); | 50 Array::Handle(Array::MakeArray(pc_offset_list)); |
46 const Stacktrace& stacktrace = Stacktrace::Handle( | 51 const Stacktrace& stacktrace = Stacktrace::Handle( |
47 Stacktrace::New(code_array, pc_offset_array)); | 52 Stacktrace::New(code_array, pc_offset_array)); |
48 OS::PrintErr("=== Current Trace:\n%s===\n", stacktrace.ToCString()); | 53 OS::PrintErr("=== Current Trace:\n%s===\n", stacktrace.ToCString()); |
49 } | 54 } |
50 | 55 |
56 DEFINE_NATIVE_ENTRY(StackTrace_current, 0) { | |
57 const GrowableObjectArray& code_list = | |
Ivan Posva
2015/11/24 00:53:58
This whole code needs to be de-deduplicated: https
Lasse Reichstein Nielsen
2015/11/24 06:52:56
I'll start by moving it to a static function in th
| |
58 GrowableObjectArray::Handle(GrowableObjectArray::New()); | |
59 const GrowableObjectArray& pc_offset_list = | |
60 GrowableObjectArray::Handle(GrowableObjectArray::New()); | |
61 // Skip the StackFrame.current frame. | |
62 IterateFrames(code_list, pc_offset_list, 1); | |
63 const Array& code_array = Array::Handle(Array::MakeArray(code_list)); | |
64 const Array& pc_offset_array = | |
65 Array::Handle(Array::MakeArray(pc_offset_list)); | |
66 const Stacktrace& stacktrace = Stacktrace::Handle( | |
67 Stacktrace::New(code_array, pc_offset_array)); | |
68 return stacktrace.raw(); | |
69 } | |
70 | |
71 | |
51 } // namespace dart | 72 } // namespace dart |
OLD | NEW |