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())); |