Index: src/messages.cc |
diff --git a/src/messages.cc b/src/messages.cc |
index 5d033189634d28dc863f243fadf57dc34acefe7c..bf0126c19785d9f7611e2ef75eeb47e2af587ca9 100644 |
--- a/src/messages.cc |
+++ b/src/messages.cc |
@@ -495,44 +495,52 @@ MaybeHandle<FixedArray> GetStackFrames(Isolate* isolate, |
Handle<JSArray> raw_stack_array = Handle<JSArray>::cast(raw_stack); |
DCHECK(raw_stack_array->elements()->IsFixedArray()); |
- Handle<FixedArray> raw_stack_elements = |
- handle(FixedArray::cast(raw_stack_array->elements()), isolate); |
+ Handle<FrameArray> elems(FrameArray::cast(raw_stack_array->elements())); |
- const int raw_stack_len = raw_stack_elements->length(); |
- DCHECK(raw_stack_len % 4 == 1); // Multiples of 4 plus sloppy frames count. |
- const int frame_count = (raw_stack_len - 1) / 4; |
+ const int frame_count = elems->FrameCount(); |
- Handle<Object> sloppy_frames_obj = |
- FixedArray::get(*raw_stack_elements, 0, isolate); |
- int sloppy_frames = Handle<Smi>::cast(sloppy_frames_obj)->value(); |
+ int sloppy_frames = elems->SloppyFrameCount(); |
- int dst_ix = 0; |
Handle<FixedArray> frames = isolate->factory()->NewFixedArray(frame_count); |
- for (int i = 1; i < raw_stack_len; i += 4) { |
- Handle<Object> recv = FixedArray::get(*raw_stack_elements, i, isolate); |
- Handle<Object> fun = FixedArray::get(*raw_stack_elements, i + 1, isolate); |
- Handle<AbstractCode> code = Handle<AbstractCode>::cast( |
- FixedArray::get(*raw_stack_elements, i + 2, isolate)); |
- Handle<Smi> pc = |
- Handle<Smi>::cast(FixedArray::get(*raw_stack_elements, i + 3, isolate)); |
- |
- Handle<Object> pos = |
- (fun->IsSmi() && pc->value() < 0) |
- ? handle(Smi::FromInt(-1 - pc->value()), isolate) |
- : handle(Smi::FromInt(code->SourcePosition(pc->value())), isolate); |
+ for (int i = 0; i < frame_count; i++) { |
+ Handle<AbstractCode> code(elems->Code(i), isolate); |
+ Handle<Smi> pc(elems->Offset(i), isolate); |
sloppy_frames--; |
Handle<Object> strict = isolate->factory()->ToBoolean(sloppy_frames < 0); |
- Handle<Object> callsite; |
- ASSIGN_RETURN_ON_EXCEPTION( |
- isolate, callsite, |
- CallSiteUtils::Construct(isolate, recv, fun, pos, strict), FixedArray); |
+ if (elems->IsWasmFrame(i)) { |
+ Handle<Object> wasm_obj(elems->WasmObject(i), isolate); |
+ Handle<Smi> wasm_fun_ix(elems->WasmFunctionIndex(i), isolate); |
+ |
+ Handle<Object> pos((pc->value() < 0) |
+ ? Smi::FromInt(-1 - pc->value()) |
+ : Smi::FromInt(code->SourcePosition(pc->value())), |
+ isolate); |
- frames->set(dst_ix++, *callsite); |
+ Handle<Object> callsite; |
+ ASSIGN_RETURN_ON_EXCEPTION( |
+ isolate, callsite, |
+ CallSiteUtils::Construct(isolate, wasm_obj, wasm_fun_ix, pos, strict), |
+ FixedArray); |
+ |
+ frames->set(i, *callsite); |
+ } else { |
+ Handle<Object> recv(elems->Receiver(i), isolate); |
+ Handle<Object> fun(elems->Function(i), isolate); |
+ Handle<Object> pos(Smi::FromInt(code->SourcePosition(pc->value())), |
+ isolate); |
+ |
+ Handle<Object> callsite; |
+ ASSIGN_RETURN_ON_EXCEPTION( |
+ isolate, callsite, |
+ CallSiteUtils::Construct(isolate, recv, fun, pos, strict), |
+ FixedArray); |
+ |
+ frames->set(i, *callsite); |
+ } |
} |
- DCHECK_EQ(frame_count, dst_ix); |
return frames; |
} |