| Index: runtime/vm/flow_graph_compiler.cc
|
| diff --git a/runtime/vm/flow_graph_compiler.cc b/runtime/vm/flow_graph_compiler.cc
|
| index 0286145f41f1e9ccf859cd4f3a93b92ac2ea353a..da35c1bd77151b325f98ede64a50969d984c007c 100644
|
| --- a/runtime/vm/flow_graph_compiler.cc
|
| +++ b/runtime/vm/flow_graph_compiler.cc
|
| @@ -227,7 +227,8 @@ bool FlowGraphCompiler::ForceSlowPathForStackOverflow() const {
|
| static bool IsEmptyBlock(BlockEntryInstr* block) {
|
| return !block->HasParallelMove() &&
|
| block->next()->IsGoto() &&
|
| - !block->next()->AsGoto()->HasParallelMove();
|
| + !block->next()->AsGoto()->HasParallelMove() &&
|
| + !block->IsIndirectEntry();
|
| }
|
|
|
|
|
| @@ -354,6 +355,7 @@ void FlowGraphCompiler::VisitBlocks() {
|
|
|
| LoopInfoComment(assembler(), *entry, *loop_headers);
|
|
|
| + entry->set_offset(assembler()->CodeSize());
|
| entry->EmitNativeCode(this);
|
| // Compile all successors until an exit, branch, or a block entry.
|
| for (ForwardInstructionIterator it(entry); !it.Done(); it.Advance()) {
|
| @@ -822,6 +824,11 @@ void FlowGraphCompiler::FinalizeStackmaps(const Code& code) {
|
|
|
|
|
| void FlowGraphCompiler::FinalizeVarDescriptors(const Code& code) {
|
| + if (parsed_function().node_sequence() == NULL) {
|
| + ASSERT(flow_graph().IsIrregexpFunction());
|
| + return;
|
| + }
|
| +
|
| const LocalVarDescriptors& var_descs = LocalVarDescriptors::Handle(
|
| parsed_function_.node_sequence()->scope()->GetVarDescriptors(
|
| parsed_function_.function()));
|
|
|