| Index: runtime/vm/flow_graph_builder.cc | 
| =================================================================== | 
| --- runtime/vm/flow_graph_builder.cc	(revision 44266) | 
| +++ runtime/vm/flow_graph_builder.cc	(working copy) | 
| @@ -43,8 +43,8 @@ | 
| DECLARE_FLAG(int, optimization_counter_threshold); | 
| DECLARE_FLAG(bool, warn_on_javascript_compatibility); | 
|  | 
| -// Quick access to the locally defined isolate() method. | 
| -#define I (isolate()) | 
| +// Quick access to the locally defined zone() method. | 
| +#define Z (zone()) | 
|  | 
| // TODO(srdjan): Allow compiler to add constants as they are encountered in | 
| // the compilation. | 
| @@ -125,7 +125,7 @@ | 
| if (label != label_) return NULL; | 
| if (break_target_ == NULL) { | 
| break_target_ = | 
| -        new(owner()->isolate()) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +        new(owner()->zone()) JoinEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| } | 
| return break_target_; | 
| @@ -183,7 +183,7 @@ | 
| if (label != this->label()) return NULL; | 
| if (continue_target_ == NULL) { | 
| continue_target_ = | 
| -        new(owner()->isolate()) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +        new(owner()->zone()) JoinEntryInstr(owner()->AllocateBlockId(), | 
| try_index()); | 
| } | 
| return continue_target_; | 
| @@ -227,7 +227,7 @@ | 
| if (label != case_labels_[i]) continue; | 
| if (case_targets_[i] == NULL) { | 
| case_targets_[i] = | 
| -          new(owner()->isolate()) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +          new(owner()->zone()) JoinEntryInstr(owner()->AllocateBlockId(), | 
| try_index()); | 
| } | 
| return case_targets_[i]; | 
| @@ -260,8 +260,8 @@ | 
| nesting_stack_(NULL), | 
| osr_id_(osr_id), | 
| jump_count_(0), | 
| -        await_joins_(new(I) ZoneGrowableArray<JoinEntryInstr*>()), | 
| -        await_levels_(new(I) ZoneGrowableArray<intptr_t>()) { } | 
| +        await_joins_(new(Z) ZoneGrowableArray<JoinEntryInstr*>()), | 
| +        await_levels_(new(Z) ZoneGrowableArray<intptr_t>()) { } | 
|  | 
|  | 
| void FlowGraphBuilder::AddCatchEntry(CatchBlockEntryInstr* entry) { | 
| @@ -294,7 +294,7 @@ | 
| } | 
| Instruction* instr = block; | 
| if (block->env() != NULL) { | 
| -      call_->env()->DeepCopyToOuter(callee_graph->isolate(), block); | 
| +      call_->env()->DeepCopyToOuter(callee_graph->zone(), block); | 
| } | 
| for (ForwardInstructionIterator it(block); !it.Done(); it.Advance()) { | 
| instr = it.Current(); | 
| @@ -302,7 +302,7 @@ | 
| // optimizations need deoptimization info for non-deoptable instructions, | 
| // eg, LICM on GOTOs. | 
| if (instr->env() != NULL) { | 
| -        call_->env()->DeepCopyToOuter(callee_graph->isolate(), instr); | 
| +        call_->env()->DeepCopyToOuter(callee_graph->zone(), instr); | 
| } | 
| } | 
| if (instr->IsGoto()) { | 
| @@ -360,7 +360,7 @@ | 
| intptr_t join_id = caller_graph_->max_block_id() + 1; | 
| caller_graph_->set_max_block_id(join_id); | 
| JoinEntryInstr* join = | 
| -        new(I) JoinEntryInstr(join_id, try_index); | 
| +        new(Z) JoinEntryInstr(join_id, try_index); | 
|  | 
| // The dominator set of the join is the intersection of the dominator | 
| // sets of all the predecessors.  If we keep the dominator sets ordered | 
| @@ -378,8 +378,8 @@ | 
| GrowableArray<BlockEntryInstr*> join_dominators; | 
| for (intptr_t i = 0; i < num_exits; ++i) { | 
| // Add the control-flow edge. | 
| -      GotoInstr* goto_instr = new(I) GotoInstr(join); | 
| -      goto_instr->InheritDeoptTarget(isolate(), ReturnAt(i)); | 
| +      GotoInstr* goto_instr = new(Z) GotoInstr(join); | 
| +      goto_instr->InheritDeoptTarget(zone(), ReturnAt(i)); | 
| LastInstructionAt(i)->LinkTo(goto_instr); | 
| ExitBlockAt(i)->set_last_instruction(LastInstructionAt(i)->next()); | 
| join->predecessors_.Add(ExitBlockAt(i)); | 
| @@ -424,7 +424,7 @@ | 
| // If the call has uses, create a phi of the returns. | 
| if (call_->HasUses()) { | 
| // Add a phi of the return values. | 
| -      PhiInstr* phi = new(I) PhiInstr(join, num_exits); | 
| +      PhiInstr* phi = new(Z) PhiInstr(join, num_exits); | 
| phi->set_ssa_temp_index(caller_graph_->alloc_ssa_temp_index()); | 
| phi->mark_alive(); | 
| for (intptr_t i = 0; i < num_exits; ++i) { | 
| @@ -464,7 +464,7 @@ | 
| // goes to the rest of the caller graph. It is removed as unreachable code | 
| // by the constant propagation. | 
| TargetEntryInstr* false_block = | 
| -        new(I) TargetEntryInstr(caller_graph_->allocate_block_id(), | 
| +        new(Z) TargetEntryInstr(caller_graph_->allocate_block_id(), | 
| call_block->try_index()); | 
| false_block->InheritDeoptTargetAfter(caller_graph_, call_, NULL); | 
| false_block->LinkTo(call_->next()); | 
| @@ -472,13 +472,13 @@ | 
|  | 
| ConstantInstr* true_const = caller_graph_->GetConstant(Bool::True()); | 
| BranchInstr* branch = | 
| -        new(I) BranchInstr( | 
| -            new(I) StrictCompareInstr(call_block->start_pos(), | 
| +        new(Z) BranchInstr( | 
| +            new(Z) StrictCompareInstr(call_block->start_pos(), | 
| Token::kEQ_STRICT, | 
| -                                      new(I) Value(true_const), | 
| -                                      new(I) Value(true_const), | 
| +                                      new(Z) Value(true_const), | 
| +                                      new(Z) Value(true_const), | 
| false));  // No number check. | 
| -    branch->InheritDeoptTarget(isolate(), call_); | 
| +    branch->InheritDeoptTarget(zone(), call_); | 
| *branch->true_successor_address() = callee_entry; | 
| *branch->false_successor_address() = false_block; | 
|  | 
| @@ -584,7 +584,7 @@ | 
| exit()->LinkTo(definition); | 
| } | 
| exit_ = definition; | 
| -  return new(I) Value(definition); | 
| +  return new(Z) Value(definition); | 
| } | 
|  | 
|  | 
| @@ -618,7 +618,7 @@ | 
|  | 
| void EffectGraphVisitor::AddReturnExit(intptr_t token_pos, Value* value) { | 
| ASSERT(is_open()); | 
| -  ReturnInstr* return_instr = new(I) ReturnInstr(token_pos, value); | 
| +  ReturnInstr* return_instr = new(Z) ReturnInstr(token_pos, value); | 
| AddInstruction(return_instr); | 
| InlineExitCollector* exit_collector = owner()->exit_collector(); | 
| if (exit_collector != NULL) { | 
| @@ -631,7 +631,7 @@ | 
| void EffectGraphVisitor::Goto(JoinEntryInstr* join) { | 
| ASSERT(is_open()); | 
| if (is_empty()) { | 
| -    entry_ = new(I) GotoInstr(join); | 
| +    entry_ = new(Z) GotoInstr(join); | 
| } else { | 
| exit()->Goto(join); | 
| } | 
| @@ -681,7 +681,7 @@ | 
| exit_ = true_exit; | 
| } else { | 
| JoinEntryInstr* join = | 
| -        new(I) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| +        new(Z) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| true_exit->Goto(join); | 
| false_exit->Goto(join); | 
| exit_ = join; | 
| @@ -712,9 +712,9 @@ | 
| Append(test_fragment); | 
| } else { | 
| JoinEntryInstr* join = | 
| -        new(I) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| +        new(Z) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| CheckStackOverflowInstr* check = | 
| -        new(I) CheckStackOverflowInstr(token_pos, owner()->loop_depth()); | 
| +        new(Z) CheckStackOverflowInstr(token_pos, owner()->loop_depth()); | 
| join->LinkTo(check); | 
| if (!test_preamble_fragment.is_empty()) { | 
| check->LinkTo(test_preamble_fragment.entry()); | 
| @@ -734,7 +734,7 @@ | 
|  | 
| PushArgumentInstr* EffectGraphVisitor::PushArgument(Value* value) { | 
| owner_->add_args_pushed(1); | 
| -  PushArgumentInstr* result = new(I) PushArgumentInstr(value); | 
| +  PushArgumentInstr* result = new(Z) PushArgumentInstr(value); | 
| AddInstruction(result); | 
| return result; | 
| } | 
| @@ -743,7 +743,7 @@ | 
| Definition* EffectGraphVisitor::BuildStoreTemp(const LocalVariable& local, | 
| Value* value) { | 
| ASSERT(!local.is_captured()); | 
| -  return new(I) StoreLocalInstr(local, value); | 
| +  return new(Z) StoreLocalInstr(local, value); | 
| } | 
|  | 
|  | 
| @@ -767,13 +767,13 @@ | 
| ASSERT(delta >= 0); | 
| Value* context = Bind(BuildCurrentContext()); | 
| while (delta-- > 0) { | 
| -      context = Bind(new(I) LoadFieldInstr( | 
| -          context, Context::parent_offset(), Type::ZoneHandle(I, Type::null()), | 
| +      context = Bind(new(Z) LoadFieldInstr( | 
| +          context, Context::parent_offset(), Type::ZoneHandle(Z, Type::null()), | 
| Scanner::kNoSourcePos)); | 
| } | 
| -    Value* tmp_val = Bind(new(I) LoadLocalInstr(*tmp_var)); | 
| +    Value* tmp_val = Bind(new(Z) LoadLocalInstr(*tmp_var)); | 
| StoreInstanceFieldInstr* store = | 
| -        new(I) StoreInstanceFieldInstr(Context::variable_offset(local.index()), | 
| +        new(Z) StoreInstanceFieldInstr(Context::variable_offset(local.index()), | 
| context, | 
| tmp_val, | 
| kEmitStoreBarrier, | 
| @@ -781,7 +781,7 @@ | 
| Do(store); | 
| return ExitTempLocalScope(tmp_var); | 
| } else { | 
| -    return new(I) StoreLocalInstr(local, value); | 
| +    return new(Z) StoreLocalInstr(local, value); | 
| } | 
| } | 
|  | 
| @@ -788,7 +788,7 @@ | 
|  | 
| Definition* EffectGraphVisitor::BuildLoadLocal(const LocalVariable& local) { | 
| if (local.IsConst()) { | 
| -    return new(I) ConstantInstr(*local.ConstValue()); | 
| +    return new(Z) ConstantInstr(*local.ConstValue()); | 
| } else if (local.is_captured()) { | 
| intptr_t delta = | 
| owner()->context_level() - local.owner()->context_level(); | 
| @@ -795,16 +795,16 @@ | 
| ASSERT(delta >= 0); | 
| Value* context = Bind(BuildCurrentContext()); | 
| while (delta-- > 0) { | 
| -      context = Bind(new(I) LoadFieldInstr( | 
| -          context, Context::parent_offset(), Type::ZoneHandle(I, Type::null()), | 
| +      context = Bind(new(Z) LoadFieldInstr( | 
| +          context, Context::parent_offset(), Type::ZoneHandle(Z, Type::null()), | 
| Scanner::kNoSourcePos)); | 
| } | 
| -    return new(I) LoadFieldInstr(context, | 
| +    return new(Z) LoadFieldInstr(context, | 
| Context::variable_offset(local.index()), | 
| local.type(), | 
| Scanner::kNoSourcePos); | 
| } else { | 
| -    return new(I) LoadLocalInstr(local); | 
| +    return new(Z) LoadLocalInstr(local); | 
| } | 
| } | 
|  | 
| @@ -824,13 +824,13 @@ | 
|  | 
|  | 
| Definition* EffectGraphVisitor::BuildStoreContext(Value* value) { | 
| -  return new(I) StoreLocalInstr( | 
| +  return new(Z) StoreLocalInstr( | 
| *owner()->parsed_function().current_context_var(), value); | 
| } | 
|  | 
|  | 
| Definition* EffectGraphVisitor::BuildCurrentContext() { | 
| -  return new(I) LoadLocalInstr( | 
| +  return new(Z) LoadLocalInstr( | 
| *owner()->parsed_function().current_context_var()); | 
| } | 
|  | 
| @@ -841,7 +841,7 @@ | 
| ASSERT(!branches.is_empty()); | 
| for (intptr_t i = 0; i < branches.length(); i++) { | 
| TargetEntryInstr* target = | 
| -        new(I) TargetEntryInstr(owner()->AllocateBlockId(), | 
| +        new(Z) TargetEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| *(branches[i]) = target; | 
| target->Goto(join); | 
| @@ -865,7 +865,7 @@ | 
|  | 
| if (branches.length() == 1) { | 
| TargetEntryInstr* target = | 
| -        new(I) TargetEntryInstr(owner()->AllocateBlockId(), | 
| +        new(Z) TargetEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| *(branches[0]) = target; | 
| return target; | 
| @@ -872,7 +872,7 @@ | 
| } | 
|  | 
| JoinEntryInstr* join = | 
| -      new(I) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| +      new(Z) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| ConnectBranchesTo(branches, join); | 
| return join; | 
| } | 
| @@ -891,16 +891,16 @@ | 
| void TestGraphVisitor::ReturnValue(Value* value) { | 
| if (Isolate::Current()->TypeChecksEnabled() || | 
| Isolate::Current()->AssertsEnabled()) { | 
| -    value = Bind(new(I) AssertBooleanInstr(condition_token_pos(), value)); | 
| +    value = Bind(new(Z) AssertBooleanInstr(condition_token_pos(), value)); | 
| } | 
| -  Value* constant_true = Bind(new(I) ConstantInstr(Bool::True())); | 
| +  Value* constant_true = Bind(new(Z) ConstantInstr(Bool::True())); | 
| StrictCompareInstr* comp = | 
| -      new(I) StrictCompareInstr(condition_token_pos(), | 
| +      new(Z) StrictCompareInstr(condition_token_pos(), | 
| Token::kEQ_STRICT, | 
| value, | 
| constant_true, | 
| false);  // No number check. | 
| -  BranchInstr* branch = new(I) BranchInstr(comp); | 
| +  BranchInstr* branch = new(Z) BranchInstr(comp); | 
| AddInstruction(branch); | 
| CloseFragment(); | 
|  | 
| @@ -913,11 +913,11 @@ | 
| BranchInstr* branch; | 
| if (Token::IsStrictEqualityOperator(comp->kind())) { | 
| ASSERT(comp->IsStrictCompare()); | 
| -    branch = new(I) BranchInstr(comp); | 
| +    branch = new(Z) BranchInstr(comp); | 
| } else if (Token::IsEqualityOperator(comp->kind()) && | 
| (comp->left()->BindsToConstantNull() || | 
| comp->right()->BindsToConstantNull())) { | 
| -    branch = new(I) BranchInstr(new(I) StrictCompareInstr( | 
| +    branch = new(Z) BranchInstr(new(Z) StrictCompareInstr( | 
| comp->token_pos(), | 
| (comp->kind() == Token::kEQ) ? Token::kEQ_STRICT : Token::kNE_STRICT, | 
| comp->left(), | 
| @@ -924,7 +924,7 @@ | 
| comp->right(), | 
| false));  // No number check. | 
| } else { | 
| -    branch = new(I) BranchInstr(comp); | 
| +    branch = new(Z) BranchInstr(comp); | 
| branch->set_is_checked(Isolate::Current()->TypeChecksEnabled()); | 
| } | 
| AddInstruction(branch); | 
| @@ -936,14 +936,14 @@ | 
|  | 
| void TestGraphVisitor::MergeBranchWithNegate(BooleanNegateInstr* neg) { | 
| ASSERT(!Isolate::Current()->TypeChecksEnabled()); | 
| -  Value* constant_true = Bind(new(I) ConstantInstr(Bool::True())); | 
| +  Value* constant_true = Bind(new(Z) ConstantInstr(Bool::True())); | 
| StrictCompareInstr* comp = | 
| -      new(I) StrictCompareInstr(condition_token_pos(), | 
| +      new(Z) StrictCompareInstr(condition_token_pos(), | 
| Token::kNE_STRICT, | 
| neg->value(), | 
| constant_true, | 
| false);  // No number check. | 
| -  BranchInstr* branch = new(I) BranchInstr(comp); | 
| +  BranchInstr* branch = new(Z) BranchInstr(comp); | 
| AddInstruction(branch); | 
| CloseFragment(); | 
| true_successor_addresses_.Add(branch->true_successor_address()); | 
| @@ -1042,7 +1042,7 @@ | 
| // statements for which there is no associated source position. | 
| const Function& function = owner()->function(); | 
| if ((node->token_pos() != Scanner::kNoSourcePos) && !function.is_native()) { | 
| -    AddInstruction(new(I) DebugStepCheckInstr(node->token_pos(), | 
| +    AddInstruction(new(Z) DebugStepCheckInstr(node->token_pos(), | 
| RawPcDescriptors::kRuntimeCall)); | 
| } | 
|  | 
| @@ -1058,7 +1058,7 @@ | 
| // However, factories may create an instance of the wrong type. | 
| if (!is_implicit_dynamic_getter && !function.IsGenerativeConstructor()) { | 
| const AbstractType& dst_type = | 
| -          AbstractType::ZoneHandle(I, function.result_type()); | 
| +          AbstractType::ZoneHandle(Z, function.result_type()); | 
| return_value = BuildAssignableValue(node->value()->token_pos(), | 
| return_value, | 
| dst_type, | 
| @@ -1084,12 +1084,12 @@ | 
| node->scope()->LookupVariable(Symbols::AsyncCompleter(), false); | 
| ASSERT(rcv_var != NULL && rcv_var->is_captured()); | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -        new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +        new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| Value* rcv_value = Bind(BuildLoadLocal(*rcv_var)); | 
| arguments->Add(PushArgument(rcv_value)); | 
| Value* returned_value = Bind(BuildLoadExprTemp()); | 
| arguments->Add(PushArgument(returned_value)); | 
| -    InstanceCallInstr* call = new(I) InstanceCallInstr( | 
| +    InstanceCallInstr* call = new(Z) InstanceCallInstr( | 
| Scanner::kNoSourcePos, | 
| Symbols::CompleterComplete(), | 
| Token::kILLEGAL, | 
| @@ -1115,7 +1115,7 @@ | 
| function.IsSyncGenClosure() || | 
| function.IsAsyncGenClosure()) && | 
| (node->return_type() == ReturnNode::kContinuationTarget)) { | 
| -    JoinEntryInstr* const join = new(I) JoinEntryInstr( | 
| +    JoinEntryInstr* const join = new(Z) JoinEntryInstr( | 
| owner()->AllocateBlockId(), owner()->try_index()); | 
| owner()->await_joins()->Add(join); | 
| exit_ = join; | 
| @@ -1125,7 +1125,7 @@ | 
|  | 
| // <Expression> ::= Literal { literal: Instance } | 
| void EffectGraphVisitor::VisitLiteralNode(LiteralNode* node) { | 
| -  ReturnDefinition(new(I) ConstantInstr(node->literal())); | 
| +  ReturnDefinition(new(Z) ConstantInstr(node->literal())); | 
| } | 
|  | 
|  | 
| @@ -1142,13 +1142,13 @@ | 
| // Type may be malbounded, but not malformed. | 
| ASSERT(type.IsFinalized() && !type.IsMalformed()); | 
| if (type.IsInstantiated()) { | 
| -    ReturnDefinition(new(I) ConstantInstr(type)); | 
| +    ReturnDefinition(new(Z) ConstantInstr(type)); | 
| } else { | 
| const Class& instantiator_class = Class::ZoneHandle( | 
| -        I, owner()->function().Owner()); | 
| +        Z, owner()->function().Owner()); | 
| Value* instantiator_value = BuildInstantiatorTypeArguments( | 
| node->token_pos(), instantiator_class, NULL); | 
| -    ReturnDefinition(new(I) InstantiateTypeInstr( | 
| +    ReturnDefinition(new(Z) InstantiateTypeInstr( | 
| node->token_pos(), type, instantiator_class, instantiator_value)); | 
| } | 
| } | 
| @@ -1213,7 +1213,7 @@ | 
| node->type(), | 
| node->dst_name())) { | 
| // Drop the value and 0 additional temporaries. | 
| -    checked_value = new(I) DropTempsInstr(0, for_value.value()); | 
| +    checked_value = new(Z) DropTempsInstr(0, for_value.value()); | 
| } else { | 
| checked_value = BuildAssertAssignable(node->expr()->token_pos(), | 
| for_value.value(), | 
| @@ -1251,7 +1251,7 @@ | 
| ValueGraphVisitor for_right(owner()); | 
| node->right()->Visit(&for_right); | 
| Value* right_value = for_right.value(); | 
| -      for_right.Do(new(I) AssertBooleanInstr(node->right()->token_pos(), | 
| +      for_right.Do(new(Z) AssertBooleanInstr(node->right()->token_pos(), | 
| right_value)); | 
| if (node->kind() == Token::kAND) { | 
| Join(for_left, for_right, empty); | 
| @@ -1280,12 +1280,12 @@ | 
| PushArgumentInstr* push_right = PushArgument(for_right_value.value()); | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| arguments->Add(push_left); | 
| arguments->Add(push_right); | 
| -  const String& name = String::ZoneHandle(I, Symbols::New(node->TokenName())); | 
| +  const String& name = String::ZoneHandle(Z, Symbols::New(node->TokenName())); | 
| const intptr_t kNumArgsChecked = 2; | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr(node->token_pos(), | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr(node->token_pos(), | 
| name, | 
| node->kind(), | 
| arguments, | 
| @@ -1315,12 +1315,12 @@ | 
| if (Isolate::Current()->TypeChecksEnabled() || | 
| Isolate::Current()->AssertsEnabled()) { | 
| right_value = | 
| -          for_right.Bind(new(I) AssertBooleanInstr(node->right()->token_pos(), | 
| +          for_right.Bind(new(Z) AssertBooleanInstr(node->right()->token_pos(), | 
| right_value)); | 
| } | 
| -    Value* constant_true = for_right.Bind(new(I) ConstantInstr(Bool::True())); | 
| +    Value* constant_true = for_right.Bind(new(Z) ConstantInstr(Bool::True())); | 
| Value* compare = | 
| -        for_right.Bind(new(I) StrictCompareInstr(node->token_pos(), | 
| +        for_right.Bind(new(Z) StrictCompareInstr(node->token_pos(), | 
| Token::kEQ_STRICT, | 
| right_value, | 
| constant_true, | 
| @@ -1330,13 +1330,13 @@ | 
| if (node->kind() == Token::kAND) { | 
| ValueGraphVisitor for_false(owner()); | 
| Value* constant_false = | 
| -          for_false.Bind(new(I) ConstantInstr(Bool::False())); | 
| +          for_false.Bind(new(Z) ConstantInstr(Bool::False())); | 
| for_false.Do(BuildStoreExprTemp(constant_false)); | 
| Join(for_test, for_right, for_false); | 
| } else { | 
| ASSERT(node->kind() == Token::kOR); | 
| ValueGraphVisitor for_true(owner()); | 
| -      Value* constant_true = for_true.Bind(new(I) ConstantInstr(Bool::True())); | 
| +      Value* constant_true = for_true.Bind(new(Z) ConstantInstr(Bool::True())); | 
| for_true.Do(BuildStoreExprTemp(constant_true)); | 
| Join(for_test, for_true, for_right); | 
| } | 
| @@ -1373,18 +1373,18 @@ | 
| Append(for_right_value); | 
| PushArgumentInstr* push_right = PushArgument(for_right_value.value()); | 
|  | 
| -  Value* mask_value = Bind(new(I) ConstantInstr( | 
| -      Integer::ZoneHandle(I, Integer::New(node->mask32(), Heap::kOld)))); | 
| +  Value* mask_value = Bind(new(Z) ConstantInstr( | 
| +      Integer::ZoneHandle(Z, Integer::New(node->mask32(), Heap::kOld)))); | 
| PushArgumentInstr* push_mask = PushArgument(mask_value); | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(3); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(3); | 
| arguments->Add(push_left); | 
| arguments->Add(push_right); | 
| // Call to special method 'BinaryOpAndMaskName(node)'. | 
| arguments->Add(push_mask); | 
| const intptr_t kNumArgsChecked = 2; | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr(node->token_pos(), | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr(node->token_pos(), | 
| BinaryOpAndMaskName(node), | 
| Token::kILLEGAL, | 
| arguments, | 
| @@ -1400,7 +1400,7 @@ | 
| PushArgumentInstr** push_instantiator_result, | 
| PushArgumentInstr** push_instantiator_type_arguments_result) { | 
| const Class& instantiator_class = Class::Handle( | 
| -      I, owner()->function().Owner()); | 
| +      Z, owner()->function().Owner()); | 
| // Since called only when type tested against is not instantiated. | 
| ASSERT(instantiator_class.NumTypeParameters() > 0); | 
| Value* instantiator_type_arguments = NULL; | 
| @@ -1430,7 +1430,7 @@ | 
| Value* instantiator = NULL; | 
| Value* instantiator_type_arguments = NULL; | 
| const Class& instantiator_class = Class::Handle( | 
| -      I, owner()->function().Owner()); | 
| +      Z, owner()->function().Owner()); | 
| // Since called only when type tested against is not instantiated. | 
| ASSERT(instantiator_class.NumTypeParameters() > 0); | 
| instantiator = BuildInstantiator(instantiator_class); | 
| @@ -1452,7 +1452,7 @@ | 
|  | 
|  | 
| Value* EffectGraphVisitor::BuildNullValue() { | 
| -  return Bind(new(I) ConstantInstr(Object::ZoneHandle(I, Object::null()))); | 
| +  return Bind(new(Z) ConstantInstr(Object::ZoneHandle(Z, Object::null()))); | 
| } | 
|  | 
|  | 
| @@ -1475,7 +1475,7 @@ | 
| } | 
|  | 
| const intptr_t deopt_id = Isolate::Current()->GetNextDeoptId(); | 
| -  return new(I) AssertAssignableInstr(token_pos, | 
| +  return new(Z) AssertAssignableInstr(token_pos, | 
| value, | 
| instantiator, | 
| instantiator_type_arguments, | 
| @@ -1517,15 +1517,15 @@ | 
| ASSERT(delta >= 0); | 
| Value* context = Bind(BuildCurrentContext()); | 
| while (delta-- > 0) { | 
| -    context = Bind(new(I) LoadFieldInstr( | 
| -        context, Context::parent_offset(), Type::ZoneHandle(I, Type::null()), | 
| +    context = Bind(new(Z) LoadFieldInstr( | 
| +        context, Context::parent_offset(), Type::ZoneHandle(Z, Type::null()), | 
| Scanner::kNoSourcePos)); | 
| } | 
| LocalVariable* temp_context_var = EnterTempLocalScope(context); | 
|  | 
| -  Value* context_val = Bind(new(I) LoadLocalInstr(*temp_context_var)); | 
| -  Value* store_val = Bind(new(I) LoadLocalInstr(*temp_iterator_var)); | 
| -  StoreInstanceFieldInstr* store = new(I) StoreInstanceFieldInstr( | 
| +  Value* context_val = Bind(new(Z) LoadLocalInstr(*temp_context_var)); | 
| +  Value* store_val = Bind(new(Z) LoadLocalInstr(*temp_iterator_var)); | 
| +  StoreInstanceFieldInstr* store = new(Z) StoreInstanceFieldInstr( | 
| Context::variable_offset(iterator_param->index()), | 
| context_val, | 
| store_val, | 
| @@ -1582,15 +1582,15 @@ | 
| ASSERT(delta >= 0); | 
| Value* context = Bind(BuildCurrentContext()); | 
| while (delta-- > 0) { | 
| -    context = Bind(new(I) LoadFieldInstr( | 
| -        context, Context::parent_offset(), Type::ZoneHandle(I, Type::null()), | 
| +    context = Bind(new(Z) LoadFieldInstr( | 
| +        context, Context::parent_offset(), Type::ZoneHandle(Z, Type::null()), | 
| Scanner::kNoSourcePos)); | 
| } | 
| LocalVariable* temp_context_var = EnterTempLocalScope(context); | 
|  | 
| -  Value* context_val = Bind(new(I) LoadLocalInstr(*temp_context_var)); | 
| -  Value* store_val = Bind(new(I) LoadLocalInstr(*temp_result_var)); | 
| -  StoreInstanceFieldInstr* store = new(I) StoreInstanceFieldInstr( | 
| +  Value* context_val = Bind(new(Z) LoadLocalInstr(*temp_context_var)); | 
| +  Value* store_val = Bind(new(Z) LoadLocalInstr(*temp_result_var)); | 
| +  StoreInstanceFieldInstr* store = new(Z) StoreInstanceFieldInstr( | 
| Context::variable_offset(continuation_result->index()), | 
| context_val, | 
| store_val, | 
| @@ -1597,9 +1597,9 @@ | 
| kEmitStoreBarrier, | 
| Scanner::kNoSourcePos); | 
| Do(store); | 
| -  context_val = Bind(new(I) LoadLocalInstr(*temp_context_var)); | 
| -  store_val = Bind(new(I) LoadLocalInstr(*temp_error_var)); | 
| -  StoreInstanceFieldInstr* store2 = new(I) StoreInstanceFieldInstr( | 
| +  context_val = Bind(new(Z) LoadLocalInstr(*temp_context_var)); | 
| +  store_val = Bind(new(Z) LoadLocalInstr(*temp_error_var)); | 
| +  StoreInstanceFieldInstr* store2 = new(Z) StoreInstanceFieldInstr( | 
| Context::variable_offset(continuation_error->index()), | 
| context_val, | 
| store_val, | 
| @@ -1607,9 +1607,9 @@ | 
| Scanner::kNoSourcePos); | 
| Do(store2); | 
|  | 
| -  context_val = Bind(new(I) LoadLocalInstr(*temp_context_var)); | 
| -  store_val = Bind(new(I) LoadLocalInstr(*temp_stack_trace_var)); | 
| -  StoreInstanceFieldInstr* store3 = new(I) StoreInstanceFieldInstr( | 
| +  context_val = Bind(new(Z) LoadLocalInstr(*temp_context_var)); | 
| +  store_val = Bind(new(Z) LoadLocalInstr(*temp_stack_trace_var)); | 
| +  StoreInstanceFieldInstr* store3 = new(Z) StoreInstanceFieldInstr( | 
| Context::variable_offset(continuation_stack_trace->index()), | 
| context_val, | 
| store_val, | 
| @@ -1669,13 +1669,13 @@ | 
| ASSERT(type.IsFinalized() && !type.IsMalformedOrMalbounded()); | 
| const bool negate_result = (node->kind() == Token::kISNOT); | 
| // All objects are instances of type T if Object type is a subtype of type T. | 
| -  const Type& object_type = Type::Handle(I, Type::ObjectType()); | 
| +  const Type& object_type = Type::Handle(Z, Type::ObjectType()); | 
| if (type.IsInstantiated() && object_type.IsSubtypeOf(type, NULL)) { | 
| // Must evaluate left side. | 
| EffectGraphVisitor for_left_value(owner()); | 
| node->left()->Visit(&for_left_value); | 
| Append(for_left_value); | 
| -    ReturnDefinition(new(I) ConstantInstr(Bool::Get(!negate_result))); | 
| +    ReturnDefinition(new(Z) ConstantInstr(Bool::Get(!negate_result))); | 
| return; | 
| } | 
| ValueGraphVisitor for_left_value(owner()); | 
| @@ -1693,19 +1693,19 @@ | 
| &push_type_args); | 
| } | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(5); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(5); | 
| arguments->Add(push_left); | 
| arguments->Add(push_instantiator); | 
| arguments->Add(push_type_args); | 
| ASSERT(!node->right()->AsTypeNode()->type().IsNull()); | 
| Value* type_arg = Bind( | 
| -      new(I) ConstantInstr(node->right()->AsTypeNode()->type())); | 
| +      new(Z) ConstantInstr(node->right()->AsTypeNode()->type())); | 
| arguments->Add(PushArgument(type_arg)); | 
| const Bool& negate = Bool::Get(node->kind() == Token::kISNOT); | 
| -  Value* negate_arg = Bind(new(I) ConstantInstr(negate)); | 
| +  Value* negate_arg = Bind(new(Z) ConstantInstr(negate)); | 
| arguments->Add(PushArgument(negate_arg)); | 
| const intptr_t kNumArgsChecked = 1; | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr( | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| Library::PrivateCoreLibName(Symbols::_instanceOf()), | 
| node->kind(), | 
| @@ -1726,7 +1726,7 @@ | 
| node->left()->Visit(&for_value); | 
| Append(for_value); | 
| const String& dst_name = String::ZoneHandle( | 
| -      I, Symbols::New(Exceptions::kCastErrorDstName)); | 
| +      Z, Symbols::New(Exceptions::kCastErrorDstName)); | 
| if (CanSkipTypeCheck(node->token_pos(), | 
| for_value.value(), | 
| type, | 
| @@ -1751,14 +1751,14 @@ | 
| &push_type_args); | 
| } | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(4); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(4); | 
| arguments->Add(push_left); | 
| arguments->Add(push_instantiator); | 
| arguments->Add(push_type_args); | 
| -  Value* type_arg = Bind(new(I) ConstantInstr(type)); | 
| +  Value* type_arg = Bind(new(Z) ConstantInstr(type)); | 
| arguments->Add(PushArgument(type_arg)); | 
| const intptr_t kNumArgsChecked = 1; | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr( | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| Library::PrivateCoreLibName(Symbols::_as()), | 
| node->kind(), | 
| @@ -1780,7 +1780,7 @@ | 
| ValueGraphVisitor for_right_value(owner()); | 
| right->Visit(&for_right_value); | 
| Append(for_right_value); | 
| -  StrictCompareInstr* comp = new(I) StrictCompareInstr(token_pos, | 
| +  StrictCompareInstr* comp = new(Z) StrictCompareInstr(token_pos, | 
| kind, | 
| for_left_value.value(), | 
| for_right_value.value(), | 
| @@ -1825,7 +1825,7 @@ | 
| } | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -        new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +        new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
|  | 
| ValueGraphVisitor for_left_value(owner()); | 
| node->left()->Visit(&for_left_value); | 
| @@ -1839,7 +1839,7 @@ | 
| PushArgumentInstr* push_right = PushArgument(for_right_value.value()); | 
| arguments->Add(push_right); | 
|  | 
| -    Definition* result = new(I) InstanceCallInstr( | 
| +    Definition* result = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| Symbols::EqualOperator(), | 
| Token::kEQ,  // Result is negated later for kNE. | 
| @@ -1851,10 +1851,10 @@ | 
| if (Isolate::Current()->TypeChecksEnabled() || | 
| Isolate::Current()->AssertsEnabled()) { | 
| Value* value = Bind(result); | 
| -        result = new(I) AssertBooleanInstr(node->token_pos(), value); | 
| +        result = new(Z) AssertBooleanInstr(node->token_pos(), value); | 
| } | 
| Value* value = Bind(result); | 
| -      result = new(I) BooleanNegateInstr(value); | 
| +      result = new(Z) BooleanNegateInstr(value); | 
| } | 
| ReturnDefinition(result); | 
| return; | 
| @@ -1861,7 +1861,7 @@ | 
| } | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
|  | 
| ValueGraphVisitor for_left_value(owner()); | 
| node->left()->Visit(&for_left_value); | 
| @@ -1876,9 +1876,9 @@ | 
| arguments->Add(push_right); | 
|  | 
| ASSERT(Token::IsRelationalOperator(node->kind())); | 
| -  InstanceCallInstr* comp = new(I) InstanceCallInstr( | 
| +  InstanceCallInstr* comp = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| -      String::ZoneHandle(I, Symbols::New(node->TokenName())), | 
| +      String::ZoneHandle(Z, Symbols::New(node->TokenName())), | 
| node->kind(), | 
| arguments, | 
| Object::null_array(), | 
| @@ -1898,9 +1898,9 @@ | 
| if (Isolate::Current()->TypeChecksEnabled() || | 
| Isolate::Current()->AssertsEnabled()) { | 
| value = | 
| -          Bind(new(I) AssertBooleanInstr(node->operand()->token_pos(), value)); | 
| +          Bind(new(Z) AssertBooleanInstr(node->operand()->token_pos(), value)); | 
| } | 
| -    BooleanNegateInstr* negate = new(I) BooleanNegateInstr(value); | 
| +    BooleanNegateInstr* negate = new(Z) BooleanNegateInstr(value); | 
| ReturnDefinition(negate); | 
| return; | 
| } | 
| @@ -1910,11 +1910,11 @@ | 
| Append(for_value); | 
| PushArgumentInstr* push_value = PushArgument(for_value.value()); | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| arguments->Add(push_value); | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr( | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| -      String::ZoneHandle(I, Symbols::New(node->TokenName())), | 
| +      String::ZoneHandle(Z, Symbols::New(node->TokenName())), | 
| node->kind(), | 
| arguments, | 
| Object::null_array(), | 
| @@ -2015,7 +2015,7 @@ | 
| // Compute the start of the statements fragment. | 
| JoinEntryInstr* statement_start = NULL; | 
| if (node->label() == NULL) { | 
| -    statement_start = new(I) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +    statement_start = new(Z) JoinEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| } else { | 
| // The case nodes are nested inside a SequenceNode that is the body of a | 
| @@ -2067,7 +2067,7 @@ | 
| exit_instruction = statement_exit; | 
| } else { | 
| if (statement_exit != NULL) { | 
| -        JoinEntryInstr* join = new(I) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +        JoinEntryInstr* join = new(Z) JoinEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| statement_exit->Goto(join); | 
| next_target->Goto(join); | 
| @@ -2151,7 +2151,7 @@ | 
|  | 
| // Tie do-while loop (test is after the body). | 
| JoinEntryInstr* body_entry_join = | 
| -      new(I) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +      new(Z) JoinEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| Goto(body_entry_join); | 
| Instruction* body_exit = AppendFragment(body_entry_join, for_body); | 
| @@ -2159,10 +2159,10 @@ | 
| JoinEntryInstr* join = nested_loop.continue_target(); | 
| if ((body_exit != NULL) || (join != NULL)) { | 
| if (join == NULL) { | 
| -      join = new(I) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +      join = new(Z) JoinEntryInstr(owner()->AllocateBlockId(), | 
| owner()->try_index()); | 
| } | 
| -    CheckStackOverflowInstr* check = new(I) CheckStackOverflowInstr( | 
| +    CheckStackOverflowInstr* check = new(Z) CheckStackOverflowInstr( | 
| node->token_pos(), owner()->loop_depth()); | 
| join->LinkTo(check); | 
| check->LinkTo(for_test.entry()); | 
| @@ -2212,7 +2212,7 @@ | 
| JoinEntryInstr* continue_join = nested_loop.continue_target(); | 
| if ((continue_join != NULL) || for_body.is_open()) { | 
| JoinEntryInstr* loop_entry = | 
| -        new(I) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| +        new(Z) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| if (continue_join != NULL) { | 
| if (for_body.is_open()) for_body.Goto(continue_join); | 
| Instruction* current = AppendFragment(continue_join, for_increment); | 
| @@ -2224,7 +2224,7 @@ | 
| Goto(loop_entry); | 
| exit_ = loop_entry; | 
| AddInstruction( | 
| -        new(I) CheckStackOverflowInstr(node->token_pos(), | 
| +        new(Z) CheckStackOverflowInstr(node->token_pos(), | 
| owner()->loop_depth())); | 
| } | 
|  | 
| @@ -2332,8 +2332,8 @@ | 
| // state. | 
| ASSERT(jump_count == owner()->await_joins()->length()); | 
| // Store the counter in :await_jump_var. | 
| -  Value* jump_val = Bind(new (I) ConstantInstr( | 
| -      Smi::ZoneHandle(I, Smi::New(jump_count)))); | 
| +  Value* jump_val = Bind(new(Z) ConstantInstr( | 
| +      Smi::ZoneHandle(Z, Smi::New(jump_count)))); | 
| Do(BuildStoreLocal(*jump_var, jump_val)); | 
| // Save the current context for resuming. | 
| BuildSaveContext(*ctx_var); | 
| @@ -2351,7 +2351,7 @@ | 
|  | 
|  | 
| LocalVariable* EffectGraphVisitor::EnterTempLocalScope(Value* value) { | 
| -  Do(new(I) PushTempInstr(value)); | 
| +  Do(new(Z) PushTempInstr(value)); | 
| owner()->AllocateTemp(); | 
|  | 
| ASSERT(value->definition()->temp_index() == (owner()->temp_count() - 1)); | 
| @@ -2359,8 +2359,8 @@ | 
| char name[64]; | 
| OS::SNPrint(name, 64, ":tmp_local%" Pd, index); | 
| LocalVariable*  var = | 
| -      new(I) LocalVariable(0, | 
| -                           String::ZoneHandle(I, Symbols::New(name)), | 
| +      new(Z) LocalVariable(0, | 
| +                           String::ZoneHandle(Z, Symbols::New(name)), | 
| *value->Type()->ToAbstractType()); | 
| var->set_index(index); | 
| return var; | 
| @@ -2368,10 +2368,10 @@ | 
|  | 
|  | 
| Definition* EffectGraphVisitor::ExitTempLocalScope(LocalVariable* var) { | 
| -    Value* tmp = Bind(new(I) LoadLocalInstr(*var)); | 
| +    Value* tmp = Bind(new(Z) LoadLocalInstr(*var)); | 
| owner()->DeallocateTemps(1); | 
| ASSERT(GetCurrentTempLocalIndex() == var->index()); | 
| -    return new(I) DropTempsInstr(1, tmp); | 
| +    return new(Z) DropTempsInstr(1, tmp); | 
| } | 
|  | 
|  | 
| @@ -2383,7 +2383,7 @@ | 
| Append(for_value); | 
| Value* temp_val = for_value.value(); | 
| node->TempAt(i)->set_index(GetCurrentTempLocalIndex()); | 
| -    Do(new(I) PushTempInstr(temp_val)); | 
| +    Do(new(Z) PushTempInstr(temp_val)); | 
| owner()->AllocateTemp(); | 
| } | 
| } | 
| @@ -2402,7 +2402,7 @@ | 
| intptr_t num_temps = node->num_temps(); | 
| if (num_temps > 0) { | 
| owner()->DeallocateTemps(num_temps); | 
| -    Do(new(I) DropTempsInstr(num_temps, NULL)); | 
| +    Do(new(Z) DropTempsInstr(num_temps, NULL)); | 
| } | 
| } | 
|  | 
| @@ -2425,7 +2425,7 @@ | 
| intptr_t num_temps = node->num_temps(); | 
| if (num_temps > 0) { | 
| owner()->DeallocateTemps(num_temps); | 
| -    ReturnDefinition(new(I) DropTempsInstr(num_temps, result_value)); | 
| +    ReturnDefinition(new(Z) DropTempsInstr(num_temps, result_value)); | 
| } else { | 
| ReturnValue(result_value); | 
| } | 
| @@ -2434,12 +2434,12 @@ | 
|  | 
| void EffectGraphVisitor::VisitArrayNode(ArrayNode* node) { | 
| const TypeArguments& type_args = | 
| -      TypeArguments::ZoneHandle(I, node->type().arguments()); | 
| +      TypeArguments::ZoneHandle(Z, node->type().arguments()); | 
| Value* element_type = BuildInstantiatedTypeArguments(node->token_pos(), | 
| type_args); | 
| Value* num_elements = | 
| -      Bind(new(I) ConstantInstr(Smi::ZoneHandle(I, Smi::New(node->length())))); | 
| -  CreateArrayInstr* create = new(I) CreateArrayInstr(node->token_pos(), | 
| +      Bind(new(Z) ConstantInstr(Smi::ZoneHandle(Z, Smi::New(node->length())))); | 
| +  CreateArrayInstr* create = new(Z) CreateArrayInstr(node->token_pos(), | 
| element_type, | 
| num_elements); | 
| Value* array_val = Bind(create); | 
| @@ -2448,9 +2448,9 @@ | 
| const intptr_t class_id = kArrayCid; | 
| const intptr_t deopt_id = Isolate::kNoDeoptId; | 
| for (int i = 0; i < node->length(); ++i) { | 
| -      Value* array = Bind(new(I) LoadLocalInstr(*tmp_var)); | 
| +      Value* array = Bind(new(Z) LoadLocalInstr(*tmp_var)); | 
| Value* index = | 
| -          Bind(new(I) ConstantInstr(Smi::ZoneHandle(I, Smi::New(i)))); | 
| +          Bind(new(Z) ConstantInstr(Smi::ZoneHandle(Z, Smi::New(i)))); | 
| ValueGraphVisitor for_value(owner()); | 
| node->ElementAt(i)->Visit(&for_value); | 
| Append(for_value); | 
| @@ -2460,7 +2460,7 @@ | 
| ? kNoStoreBarrier | 
| : kEmitStoreBarrier; | 
| const intptr_t index_scale = Instance::ElementSizeFor(class_id); | 
| -      StoreIndexedInstr* store = new(I) StoreIndexedInstr( | 
| +      StoreIndexedInstr* store = new(Z) StoreIndexedInstr( | 
| array, index, for_value.value(), emit_store_barrier, | 
| index_scale, class_id, deopt_id, node->token_pos()); | 
| Do(store); | 
| @@ -2476,7 +2476,7 @@ | 
| ArrayNode* arguments = node->value(); | 
| if (arguments->length() == 1) { | 
| ZoneGrowableArray<PushArgumentInstr*>* values = | 
| -        new(I) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| +        new(Z) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| arguments->ElementAt(0)->Visit(&for_argument); | 
| Append(for_argument); | 
| PushArgumentInstr* push_arg = PushArgument(for_argument.value()); | 
| @@ -2487,7 +2487,7 @@ | 
| Class::Handle(Library::LookupCoreClass(Symbols::StringBase())); | 
| ASSERT(!cls.IsNull()); | 
| const Function& function = Function::ZoneHandle( | 
| -        isolate(), | 
| +        Z, | 
| Resolver::ResolveStatic( | 
| cls, | 
| Library::PrivateCoreLibName(Symbols::InterpolateSingle()), | 
| @@ -2494,7 +2494,7 @@ | 
| kNumberOfArguments, | 
| kNoArgumentNames)); | 
| StaticCallInstr* call = | 
| -        new(I) StaticCallInstr(node->token_pos(), | 
| +        new(Z) StaticCallInstr(node->token_pos(), | 
| function, | 
| kNoArgumentNames, | 
| values, | 
| @@ -2505,7 +2505,7 @@ | 
| arguments->Visit(&for_argument); | 
| Append(for_argument); | 
| StringInterpolateInstr* instr = | 
| -      new(I) StringInterpolateInstr(for_argument.value(), node->token_pos()); | 
| +      new(Z) StringInterpolateInstr(for_argument.value(), node->token_pos()); | 
| ReturnDefinition(instr); | 
| } | 
|  | 
| @@ -2515,8 +2515,8 @@ | 
|  | 
| if (function.IsImplicitStaticClosureFunction()) { | 
| const Instance& closure = | 
| -        Instance::ZoneHandle(I, function.ImplicitStaticClosure()); | 
| -    ReturnDefinition(new(I) ConstantInstr(closure)); | 
| +        Instance::ZoneHandle(Z, function.ImplicitStaticClosure()); | 
| +    ReturnDefinition(new(Z) ConstantInstr(closure)); | 
| return; | 
| } | 
| const bool is_implicit = function.IsImplicitInstanceClosureFunction(); | 
| @@ -2526,11 +2526,11 @@ | 
| if (function.context_scope() == ContextScope::null()) { | 
| ASSERT(!is_implicit); | 
| const ContextScope& context_scope = ContextScope::ZoneHandle( | 
| -        I, node->scope()->PreserveOuterScope(owner()->context_level())); | 
| +        Z, node->scope()->PreserveOuterScope(owner()->context_level())); | 
| ASSERT(!function.HasCode()); | 
| ASSERT(function.context_scope() == ContextScope::null()); | 
| function.set_context_scope(context_scope); | 
| -    const Class& cls = Class::Handle(I, owner()->function().Owner()); | 
| +    const Class& cls = Class::Handle(Z, owner()->function().Owner()); | 
| // The closure is now properly setup, add it to the lookup table. | 
| // It is possible that the compiler creates more than one function | 
| // object for the same closure, e.g. when inlining nodes from | 
| @@ -2542,7 +2542,7 @@ | 
| // parent, and one with a closurized parent function. | 
|  | 
| const Function& found_func = Function::Handle( | 
| -        I, cls.LookupClosureFunction(function.token_pos())); | 
| +        Z, cls.LookupClosureFunction(function.token_pos())); | 
|  | 
| if (found_func.IsNull() || | 
| (found_func.token_pos() != function.token_pos()) || | 
| @@ -2552,12 +2552,12 @@ | 
| } | 
| } | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| ASSERT(function.context_scope() != ContextScope::null()); | 
|  | 
| // The function type of a closure may have type arguments. In that case, | 
| // pass the type arguments of the instantiator. | 
| -  const Class& cls = Class::ZoneHandle(I, function.signature_class()); | 
| +  const Class& cls = Class::ZoneHandle(Z, function.signature_class()); | 
| ASSERT(!cls.IsNull()); | 
| const bool requires_type_arguments = cls.NumTypeArguments() > 0; | 
| Value* type_arguments = NULL; | 
| @@ -2566,13 +2566,13 @@ | 
| Closure::type_arguments_offset()); | 
| ASSERT(cls.instance_size() == Closure::InstanceSize()); | 
| const Class& instantiator_class = Class::Handle( | 
| -        I, owner()->function().Owner()); | 
| +        Z, owner()->function().Owner()); | 
| type_arguments = BuildInstantiatorTypeArguments(node->token_pos(), | 
| instantiator_class, | 
| NULL); | 
| arguments->Add(PushArgument(type_arguments)); | 
| } | 
| -  AllocateObjectInstr* alloc = new(I) AllocateObjectInstr(node->token_pos(), | 
| +  AllocateObjectInstr* alloc = new(Z) AllocateObjectInstr(node->token_pos(), | 
| cls, | 
| arguments); | 
| alloc->set_closure_function(function); | 
| @@ -2580,10 +2580,10 @@ | 
| Value* closure_val = Bind(alloc); | 
| { LocalVariable* closure_tmp_var = EnterTempLocalScope(closure_val); | 
| // Store function. | 
| -    Value* closure_tmp_val = Bind(new(I) LoadLocalInstr(*closure_tmp_var)); | 
| +    Value* closure_tmp_val = Bind(new(Z) LoadLocalInstr(*closure_tmp_var)); | 
| Value* func_val = | 
| -        Bind(new(I) ConstantInstr(Function::ZoneHandle(I, function.raw()))); | 
| -    Do(new(I) StoreInstanceFieldInstr(Closure::function_offset(), | 
| +        Bind(new(Z) ConstantInstr(Function::ZoneHandle(Z, function.raw()))); | 
| +    Do(new(Z) StoreInstanceFieldInstr(Closure::function_offset(), | 
| closure_tmp_val, | 
| func_val, | 
| kEmitStoreBarrier, | 
| @@ -2592,24 +2592,24 @@ | 
| // Create new context containing the receiver. | 
| const intptr_t kNumContextVariables = 1;  // The receiver. | 
| Value* allocated_context = | 
| -          Bind(new(I) AllocateContextInstr(node->token_pos(), | 
| +          Bind(new(Z) AllocateContextInstr(node->token_pos(), | 
| kNumContextVariables)); | 
| { LocalVariable* context_tmp_var = EnterTempLocalScope(allocated_context); | 
| // Store receiver in context. | 
| -        Value* context_tmp_val = Bind(new(I) LoadLocalInstr(*context_tmp_var)); | 
| +        Value* context_tmp_val = Bind(new(Z) LoadLocalInstr(*context_tmp_var)); | 
| ValueGraphVisitor for_receiver(owner()); | 
| node->receiver()->Visit(&for_receiver); | 
| Append(for_receiver); | 
| Value* receiver = for_receiver.value(); | 
| -        Do(new(I) StoreInstanceFieldInstr(Context::variable_offset(0), | 
| +        Do(new(Z) StoreInstanceFieldInstr(Context::variable_offset(0), | 
| context_tmp_val, | 
| receiver, | 
| kEmitStoreBarrier, | 
| node->token_pos())); | 
| // Store new context in closure. | 
| -        closure_tmp_val = Bind(new(I) LoadLocalInstr(*closure_tmp_var)); | 
| -        context_tmp_val = Bind(new(I) LoadLocalInstr(*context_tmp_var)); | 
| -        Do(new(I) StoreInstanceFieldInstr(Closure::context_offset(), | 
| +        closure_tmp_val = Bind(new(Z) LoadLocalInstr(*closure_tmp_var)); | 
| +        context_tmp_val = Bind(new(Z) LoadLocalInstr(*context_tmp_var)); | 
| +        Do(new(Z) StoreInstanceFieldInstr(Closure::context_offset(), | 
| closure_tmp_val, | 
| context_tmp_val, | 
| kEmitStoreBarrier, | 
| @@ -2618,9 +2618,9 @@ | 
| } | 
| } else { | 
| // Store current context in closure. | 
| -      closure_tmp_val = Bind(new(I) LoadLocalInstr(*closure_tmp_var)); | 
| +      closure_tmp_val = Bind(new(Z) LoadLocalInstr(*closure_tmp_var)); | 
| Value* context = Bind(BuildCurrentContext()); | 
| -      Do(new(I) StoreInstanceFieldInstr(Closure::context_offset(), | 
| +      Do(new(Z) StoreInstanceFieldInstr(Closure::context_offset(), | 
| closure_tmp_val, | 
| context, | 
| kEmitStoreBarrier, | 
| @@ -2650,12 +2650,12 @@ | 
| Append(for_receiver); | 
| PushArgumentInstr* push_receiver = PushArgument(for_receiver.value()); | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>( | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>( | 
| node->arguments()->length() + 1); | 
| arguments->Add(push_receiver); | 
|  | 
| BuildPushArguments(*node->arguments(), arguments); | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr( | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| node->function_name(), | 
| Token::kILLEGAL, | 
| @@ -2701,10 +2701,10 @@ | 
| //                               arguments: <ArgumentList> } | 
| void EffectGraphVisitor::VisitStaticCallNode(StaticCallNode* node) { | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(node->arguments()->length()); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(node->arguments()->length()); | 
| BuildPushArguments(*node->arguments(), arguments); | 
| StaticCallInstr* call = | 
| -      new(I) StaticCallInstr(node->token_pos(), | 
| +      new(Z) StaticCallInstr(node->token_pos(), | 
| node->function(), | 
| node->arguments()->names(), | 
| arguments, | 
| @@ -2729,26 +2729,26 @@ | 
| LocalVariable* tmp_var = EnterTempLocalScope(for_closure.value()); | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(node->arguments()->length()); | 
| -  Value* closure_val = Bind(new(I) LoadLocalInstr(*tmp_var)); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(node->arguments()->length()); | 
| +  Value* closure_val = Bind(new(Z) LoadLocalInstr(*tmp_var)); | 
| PushArgumentInstr* push_closure = PushArgument(closure_val); | 
| arguments->Add(push_closure); | 
| BuildPushArguments(*node->arguments(), arguments); | 
|  | 
| -  closure_val = Bind(new(I) LoadLocalInstr(*tmp_var)); | 
| -  LoadFieldInstr* function_load = new(I) LoadFieldInstr( | 
| +  closure_val = Bind(new(Z) LoadLocalInstr(*tmp_var)); | 
| +  LoadFieldInstr* function_load = new(Z) LoadFieldInstr( | 
| closure_val, | 
| Closure::function_offset(), | 
| -      AbstractType::ZoneHandle(I, AbstractType::null()), | 
| +      AbstractType::ZoneHandle(Z, AbstractType::null()), | 
| node->token_pos()); | 
| function_load->set_is_immutable(true); | 
| Value* function_val = Bind(function_load); | 
|  | 
| Definition* closure_call = | 
| -      new(I) ClosureCallInstr(function_val, node, arguments); | 
| +      new(Z) ClosureCallInstr(function_val, node, arguments); | 
| if (result_needed) { | 
| Value* result = Bind(closure_call); | 
| -    Do(new(I) StoreLocalInstr(*tmp_var, result)); | 
| +    Do(new(Z) StoreLocalInstr(*tmp_var, result)); | 
| } else { | 
| Do(closure_call); | 
| } | 
| @@ -2767,24 +2767,24 @@ | 
|  | 
|  | 
| void EffectGraphVisitor::VisitInitStaticFieldNode(InitStaticFieldNode* node) { | 
| -  Value* field = Bind(new(I) ConstantInstr(node->field())); | 
| -  AddInstruction(new(I) InitStaticFieldInstr(field, node->field())); | 
| +  Value* field = Bind(new(Z) ConstantInstr(node->field())); | 
| +  AddInstruction(new(Z) InitStaticFieldInstr(field, node->field())); | 
| } | 
|  | 
|  | 
| void EffectGraphVisitor::VisitCloneContextNode(CloneContextNode* node) { | 
| Value* context = Bind(BuildCurrentContext()); | 
| -  Value* clone = Bind(new(I) CloneContextInstr(node->token_pos(), context)); | 
| +  Value* clone = Bind(new(Z) CloneContextInstr(node->token_pos(), context)); | 
| Do(BuildStoreContext(clone)); | 
| } | 
|  | 
|  | 
| Value* EffectGraphVisitor::BuildObjectAllocation(ConstructorCallNode* node) { | 
| -  const Class& cls = Class::ZoneHandle(I, node->constructor().Owner()); | 
| +  const Class& cls = Class::ZoneHandle(Z, node->constructor().Owner()); | 
| const bool cls_is_parameterized = cls.NumTypeArguments() > 0; | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* allocate_arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>( | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>( | 
| cls_is_parameterized ? 1 : 0); | 
| if (cls_is_parameterized) { | 
| Value* type_args = BuildInstantiatedTypeArguments(node->token_pos(), | 
| @@ -2792,9 +2792,9 @@ | 
| allocate_arguments->Add(PushArgument(type_args)); | 
| } | 
|  | 
| -  Definition* allocation = new(I) AllocateObjectInstr( | 
| +  Definition* allocation = new(Z) AllocateObjectInstr( | 
| node->token_pos(), | 
| -      Class::ZoneHandle(I, node->constructor().Owner()), | 
| +      Class::ZoneHandle(Z, node->constructor().Owner()), | 
| allocate_arguments); | 
|  | 
| return Bind(allocation); | 
| @@ -2804,17 +2804,17 @@ | 
| void EffectGraphVisitor::BuildConstructorCall( | 
| ConstructorCallNode* node, | 
| PushArgumentInstr* push_alloc_value) { | 
| -  Value* ctor_arg = Bind(new(I) ConstantInstr( | 
| -      Smi::ZoneHandle(I, Smi::New(Function::kCtorPhaseAll)))); | 
| +  Value* ctor_arg = Bind(new(Z) ConstantInstr( | 
| +      Smi::ZoneHandle(Z, Smi::New(Function::kCtorPhaseAll)))); | 
| PushArgumentInstr* push_ctor_arg = PushArgument(ctor_arg); | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| arguments->Add(push_alloc_value); | 
| arguments->Add(push_ctor_arg); | 
|  | 
| BuildPushArguments(*node->arguments(), arguments); | 
| -  Do(new(I) StaticCallInstr(node->token_pos(), | 
| +  Do(new(Z) StaticCallInstr(node->token_pos(), | 
| node->constructor(), | 
| node->arguments()->names(), | 
| arguments, | 
| @@ -2849,7 +2849,7 @@ | 
| void EffectGraphVisitor::VisitConstructorCallNode(ConstructorCallNode* node) { | 
| if (node->constructor().IsFactory()) { | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -        new(I) ZoneGrowableArray<PushArgumentInstr*>(); | 
| +        new(Z) ZoneGrowableArray<PushArgumentInstr*>(); | 
| PushArgumentInstr* push_type_arguments = PushArgument( | 
| BuildInstantiatedTypeArguments(node->token_pos(), | 
| node->type_arguments())); | 
| @@ -2857,7 +2857,7 @@ | 
| ASSERT(arguments->length() == 1); | 
| BuildPushArguments(*node->arguments(), arguments); | 
| StaticCallInstr* call = | 
| -        new(I) StaticCallInstr(node->token_pos(), | 
| +        new(Z) StaticCallInstr(node->token_pos(), | 
| node->constructor(), | 
| node->arguments()->names(), | 
| arguments, | 
| @@ -2888,7 +2888,7 @@ | 
|  | 
| Value* EffectGraphVisitor::BuildInstantiator(const Class& instantiator_class) { | 
| ASSERT(instantiator_class.NumTypeParameters() > 0); | 
| -  Function& outer_function = Function::Handle(I, owner()->function().raw()); | 
| +  Function& outer_function = Function::Handle(Z, owner()->function().raw()); | 
| while (outer_function.IsLocalFunction()) { | 
| outer_function = outer_function.parent_function(); | 
| } | 
| @@ -2912,10 +2912,10 @@ | 
| if (instantiator_class.NumTypeParameters() == 0) { | 
| // The type arguments are compile time constants. | 
| TypeArguments& type_arguments = | 
| -        TypeArguments::ZoneHandle(I, TypeArguments::null()); | 
| +        TypeArguments::ZoneHandle(Z, TypeArguments::null()); | 
| // Type is temporary. Only its type arguments are preserved. | 
| Type& type = Type::Handle( | 
| -        I, | 
| +        Z, | 
| Type::New(instantiator_class, type_arguments, token_pos, Heap::kNew)); | 
| type ^= ClassFinalizer::FinalizeType( | 
| instantiator_class, type, ClassFinalizer::kFinalize); | 
| @@ -2922,9 +2922,9 @@ | 
| ASSERT(!type.IsMalformedOrMalbounded()); | 
| type_arguments = type.arguments(); | 
| type_arguments = type_arguments.Canonicalize(); | 
| -    return Bind(new(I) ConstantInstr(type_arguments)); | 
| +    return Bind(new(Z) ConstantInstr(type_arguments)); | 
| } | 
| -  Function& outer_function = Function::Handle(I, owner()->function().raw()); | 
| +  Function& outer_function = Function::Handle(Z, owner()->function().raw()); | 
| while (outer_function.IsLocalFunction()) { | 
| outer_function = outer_function.parent_function(); | 
| } | 
| @@ -2947,10 +2947,10 @@ | 
| instantiator_class.type_arguments_field_offset(); | 
| ASSERT(type_arguments_field_offset != Class::kNoTypeArguments); | 
|  | 
| -  return Bind(new(I) LoadFieldInstr( | 
| +  return Bind(new(Z) LoadFieldInstr( | 
| instantiator, | 
| type_arguments_field_offset, | 
| -      Type::ZoneHandle(I, Type::null()),  // Not an instance, no type. | 
| +      Type::ZoneHandle(Z, Type::null()),  // Not an instance, no type. | 
| Scanner::kNoSourcePos)); | 
| } | 
|  | 
| @@ -2959,11 +2959,11 @@ | 
| intptr_t token_pos, | 
| const TypeArguments& type_arguments) { | 
| if (type_arguments.IsNull() || type_arguments.IsInstantiated()) { | 
| -    return Bind(new(I) ConstantInstr(type_arguments)); | 
| +    return Bind(new(Z) ConstantInstr(type_arguments)); | 
| } | 
| // The type arguments are uninstantiated. | 
| const Class& instantiator_class = Class::ZoneHandle( | 
| -      I, owner()->function().Owner()); | 
| +      Z, owner()->function().Owner()); | 
| Value* instantiator_value = | 
| BuildInstantiatorTypeArguments(token_pos, instantiator_class, NULL); | 
| const bool use_instantiator_type_args = | 
| @@ -2972,7 +2972,7 @@ | 
| if (use_instantiator_type_args) { | 
| return instantiator_value; | 
| } else { | 
| -    return Bind(new(I) InstantiateTypeArgumentsInstr(token_pos, | 
| +    return Bind(new(Z) InstantiateTypeArgumentsInstr(token_pos, | 
| type_arguments, | 
| instantiator_class, | 
| instantiator_value)); | 
| @@ -2996,7 +2996,7 @@ | 
|  | 
| Value* allocate = BuildObjectAllocation(node); | 
| { LocalVariable* tmp_var = EnterTempLocalScope(allocate); | 
| -    Value* allocated_tmp = Bind(new(I) LoadLocalInstr(*tmp_var)); | 
| +    Value* allocated_tmp = Bind(new(Z) LoadLocalInstr(*tmp_var)); | 
| PushArgumentInstr* push_allocated_value = PushArgument(allocated_tmp); | 
| BuildConstructorCall(node, push_allocated_value); | 
| ReturnDefinition(ExitTempLocalScope(tmp_var)); | 
| @@ -3010,11 +3010,11 @@ | 
| Append(for_receiver); | 
| PushArgumentInstr* push_receiver = PushArgument(for_receiver.value()); | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| arguments->Add(push_receiver); | 
| const String& name = | 
| -      String::ZoneHandle(I, Field::GetterSymbol(node->field_name())); | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr( | 
| +      String::ZoneHandle(Z, Field::GetterSymbol(node->field_name())); | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| name, | 
| Token::kGET, | 
| @@ -3050,11 +3050,11 @@ | 
|  | 
| void EffectGraphVisitor::VisitInstanceSetterNode(InstanceSetterNode* node) { | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| BuildInstanceSetterArguments(node, arguments, kResultNotNeeded); | 
| const String& name = | 
| -      String::ZoneHandle(I, Field::SetterSymbol(node->field_name())); | 
| -  InstanceCallInstr* call = new(I) InstanceCallInstr(node->token_pos(), | 
| +      String::ZoneHandle(Z, Field::SetterSymbol(node->field_name())); | 
| +  InstanceCallInstr* call = new(Z) InstanceCallInstr(node->token_pos(), | 
| name, | 
| Token::kSET, | 
| arguments, | 
| @@ -3067,11 +3067,11 @@ | 
|  | 
| void ValueGraphVisitor::VisitInstanceSetterNode(InstanceSetterNode* node) { | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| BuildInstanceSetterArguments(node, arguments, kResultNeeded); | 
| const String& name = | 
| -      String::ZoneHandle(I, Field::SetterSymbol(node->field_name())); | 
| -  Do(new(I) InstanceCallInstr(node->token_pos(), | 
| +      String::ZoneHandle(Z, Field::SetterSymbol(node->field_name())); | 
| +  Do(new(Z) InstanceCallInstr(node->token_pos(), | 
| name, | 
| Token::kSET, | 
| arguments, | 
| @@ -3084,10 +3084,10 @@ | 
|  | 
| void EffectGraphVisitor::VisitStaticGetterNode(StaticGetterNode* node) { | 
| const String& getter_name = | 
| -      String::ZoneHandle(I, Field::GetterSymbol(node->field_name())); | 
| +      String::ZoneHandle(Z, Field::GetterSymbol(node->field_name())); | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(); | 
| -  Function& getter_function = Function::ZoneHandle(I, Function::null()); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(); | 
| +  Function& getter_function = Function::ZoneHandle(Z, Function::null()); | 
| if (node->is_super_getter()) { | 
| // Statically resolved instance getter, i.e. "super getter". | 
| ASSERT(node->receiver() != NULL); | 
| @@ -3094,7 +3094,7 @@ | 
| getter_function = Resolver::ResolveDynamicAnyArgs(node->cls(), getter_name); | 
| if (getter_function.IsNull()) { | 
| // Resolve and call noSuchMethod. | 
| -      ArgumentListNode* arguments = new(I) ArgumentListNode(node->token_pos()); | 
| +      ArgumentListNode* arguments = new(Z) ArgumentListNode(node->token_pos()); | 
| arguments->Add(node->receiver()); | 
| StaticCallInstr* call = | 
| BuildStaticNoSuchMethodCall(node->cls(), | 
| @@ -3144,7 +3144,7 @@ | 
| } | 
| } | 
| ASSERT(!getter_function.IsNull()); | 
| -  StaticCallInstr* call = new(I) StaticCallInstr( | 
| +  StaticCallInstr* call = new(Z) StaticCallInstr( | 
| node->token_pos(), | 
| getter_function, | 
| Object::null_array(),  // No names | 
| @@ -3157,15 +3157,15 @@ | 
| void EffectGraphVisitor::BuildStaticSetter(StaticSetterNode* node, | 
| bool result_is_needed) { | 
| const String& setter_name = | 
| -      String::ZoneHandle(I, Field::SetterSymbol(node->field_name())); | 
| +      String::ZoneHandle(Z, Field::SetterSymbol(node->field_name())); | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(1); | 
| // A super setter is an instance setter whose setter function is | 
| // resolved at compile time (in the caller instance getter's super class). | 
| // Unlike a static getter, a super getter has a receiver parameter. | 
| const bool is_super_setter = (node->receiver() != NULL); | 
| Function& setter_function = | 
| -      Function::ZoneHandle(I, is_super_setter | 
| +      Function::ZoneHandle(Z, is_super_setter | 
| ? Resolver::ResolveDynamicAnyArgs(node->cls(), setter_name) | 
| : node->cls().LookupStaticFunction(setter_name)); | 
| StaticCallInstr* call; | 
| @@ -3173,7 +3173,7 @@ | 
| if (is_super_setter) { | 
| ASSERT(node->receiver() != NULL); | 
| // Resolve and call noSuchMethod. | 
| -      ArgumentListNode* arguments = new(I) ArgumentListNode(node->token_pos()); | 
| +      ArgumentListNode* arguments = new(Z) ArgumentListNode(node->token_pos()); | 
| arguments->Add(node->receiver()); | 
| arguments->Add(node->value()); | 
| call = BuildStaticNoSuchMethodCall( | 
| @@ -3185,7 +3185,7 @@ | 
| true);  // Super invocation. | 
| } else { | 
| // Throw a NoSuchMethodError. | 
| -      ArgumentListNode* arguments = new(I) ArgumentListNode(node->token_pos()); | 
| +      ArgumentListNode* arguments = new(Z) ArgumentListNode(node->token_pos()); | 
| arguments->Add(node->value()); | 
| call = BuildThrowNoSuchMethodError( | 
| node->token_pos(), | 
| @@ -3217,7 +3217,7 @@ | 
| } | 
| arguments->Add(PushArgument(value)); | 
|  | 
| -    call = new(I) StaticCallInstr(node->token_pos(), | 
| +    call = new(Z) StaticCallInstr(node->token_pos(), | 
| setter_function, | 
| Object::null_array(),  // No names. | 
| arguments, | 
| @@ -3264,7 +3264,7 @@ | 
| LoadLocalInstr* EffectGraphVisitor::BuildLoadThisVar(LocalScope* scope) { | 
| LocalVariable* receiver_var = scope->LookupVariable(Symbols::This(), | 
| true);  // Test only. | 
| -  return new(I) LoadLocalInstr(*receiver_var); | 
| +  return new(Z) LoadLocalInstr(*receiver_var); | 
| } | 
|  | 
|  | 
| @@ -3278,11 +3278,11 @@ | 
| LocalVariable* other_var = | 
| node->scope()->LookupVariable(Symbols::Other(), | 
| true);  // Test only. | 
| -        Value* other = Bind(new(I) LoadLocalInstr(*other_var)); | 
| +        Value* other = Bind(new(Z) LoadLocalInstr(*other_var)); | 
| // Receiver is not a number because numbers override equality. | 
| const bool kNoNumberCheck = false; | 
| StrictCompareInstr* compare = | 
| -            new(I) StrictCompareInstr(node->token_pos(), | 
| +            new(Z) StrictCompareInstr(node->token_pos(), | 
| Token::kEQ_STRICT, | 
| receiver, | 
| other, | 
| @@ -3296,10 +3296,10 @@ | 
| // avoid hoisting them since we can't hoist the preceding class-check. | 
| // This is because of externalization of strings that affects their | 
| // class-id. | 
| -        LoadFieldInstr* load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* load = new(Z) LoadFieldInstr( | 
| receiver, | 
| String::length_offset(), | 
| -            Type::ZoneHandle(I, Type::SmiType()), | 
| +            Type::ZoneHandle(Z, Type::SmiType()), | 
| node->token_pos()); | 
| load->set_result_cid(kSmiCid); | 
| load->set_recognized_kind(MethodRecognizer::kStringBaseLength); | 
| @@ -3307,11 +3307,11 @@ | 
| return ReturnDefinition(load); | 
| } | 
| ASSERT(kind == MethodRecognizer::kStringBaseIsEmpty); | 
| -        Value* zero_val = Bind(new(I) ConstantInstr( | 
| -            Smi::ZoneHandle(I, Smi::New(0)))); | 
| +        Value* zero_val = Bind(new(Z) ConstantInstr( | 
| +            Smi::ZoneHandle(Z, Smi::New(0)))); | 
| Value* load_val = Bind(load); | 
| StrictCompareInstr* compare = | 
| -            new(I) StrictCompareInstr(node->token_pos(), | 
| +            new(Z) StrictCompareInstr(node->token_pos(), | 
| Token::kEQ_STRICT, | 
| load_val, | 
| zero_val, | 
| @@ -3323,10 +3323,10 @@ | 
| case MethodRecognizer::kImmutableArrayLength: | 
| case MethodRecognizer::kTypedDataLength: { | 
| Value* receiver = Bind(BuildLoadThisVar(node->scope())); | 
| -        LoadFieldInstr* load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* load = new(Z) LoadFieldInstr( | 
| receiver, | 
| OffsetForLengthGetter(kind), | 
| -            Type::ZoneHandle(I, Type::SmiType()), | 
| +            Type::ZoneHandle(Z, Type::SmiType()), | 
| node->token_pos()); | 
| load->set_is_immutable(kind != MethodRecognizer::kGrowableArrayLength); | 
| load->set_result_cid(kSmiCid); | 
| @@ -3336,23 +3336,23 @@ | 
| case MethodRecognizer::kClassIDgetID: { | 
| LocalVariable* value_var = | 
| node->scope()->LookupVariable(Symbols::Value(), true); | 
| -        Value* value = Bind(new(I) LoadLocalInstr(*value_var)); | 
| -        LoadClassIdInstr* load = new(I) LoadClassIdInstr(value); | 
| +        Value* value = Bind(new(Z) LoadLocalInstr(*value_var)); | 
| +        LoadClassIdInstr* load = new(Z) LoadClassIdInstr(value); | 
| return ReturnDefinition(load); | 
| } | 
| case MethodRecognizer::kGrowableArrayCapacity: { | 
| Value* receiver = Bind(BuildLoadThisVar(node->scope())); | 
| -        LoadFieldInstr* data_load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* data_load = new(Z) LoadFieldInstr( | 
| receiver, | 
| Array::data_offset(), | 
| -            Type::ZoneHandle(I, Type::DynamicType()), | 
| +            Type::ZoneHandle(Z, Type::DynamicType()), | 
| node->token_pos()); | 
| data_load->set_result_cid(kArrayCid); | 
| Value* data = Bind(data_load); | 
| -        LoadFieldInstr* length_load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* length_load = new(Z) LoadFieldInstr( | 
| data, | 
| Array::length_offset(), | 
| -            Type::ZoneHandle(I, Type::SmiType()), | 
| +            Type::ZoneHandle(Z, Type::SmiType()), | 
| node->token_pos()); | 
| length_load->set_result_cid(kSmiCid); | 
| length_load->set_recognized_kind(MethodRecognizer::kObjectArrayLength); | 
| @@ -3362,10 +3362,10 @@ | 
| LocalVariable* type_args_parameter = | 
| node->scope()->LookupVariable(Symbols::TypeArgumentsParameter(), | 
| true); | 
| -        Value* element_type = Bind(new(I) LoadLocalInstr(*type_args_parameter)); | 
| +        Value* element_type = Bind(new(Z) LoadLocalInstr(*type_args_parameter)); | 
| LocalVariable* length_parameter = | 
| node->scope()->LookupVariable(Symbols::Length(), true); | 
| -        Value* length = Bind(new(I) LoadLocalInstr(*length_parameter)); | 
| +        Value* length = Bind(new(Z) LoadLocalInstr(*length_parameter)); | 
| CreateArrayInstr* create_array = | 
| new CreateArrayInstr(node->token_pos(), element_type, length); | 
| return ReturnDefinition(create_array); | 
| @@ -3372,10 +3372,10 @@ | 
| } | 
| case MethodRecognizer::kBigint_getDigits: { | 
| Value* receiver = Bind(BuildLoadThisVar(node->scope())); | 
| -        LoadFieldInstr* load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* load = new(Z) LoadFieldInstr( | 
| receiver, | 
| Bigint::digits_offset(), | 
| -            Type::ZoneHandle(I, Type::DynamicType()), | 
| +            Type::ZoneHandle(Z, Type::DynamicType()), | 
| node->token_pos()); | 
| load->set_result_cid(kTypedDataUint32ArrayCid); | 
| load->set_recognized_kind(kind); | 
| @@ -3383,10 +3383,10 @@ | 
| } | 
| case MethodRecognizer::kBigint_getUsed: { | 
| Value* receiver = Bind(BuildLoadThisVar(node->scope())); | 
| -        LoadFieldInstr* load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* load = new(Z) LoadFieldInstr( | 
| receiver, | 
| Bigint::used_offset(), | 
| -            Type::ZoneHandle(I, Type::SmiType()), | 
| +            Type::ZoneHandle(Z, Type::SmiType()), | 
| node->token_pos()); | 
| load->set_result_cid(kSmiCid); | 
| load->set_recognized_kind(kind); | 
| @@ -3394,10 +3394,10 @@ | 
| } | 
| case MethodRecognizer::kBigint_getNeg: { | 
| Value* receiver = Bind(BuildLoadThisVar(node->scope())); | 
| -        LoadFieldInstr* load = new(I) LoadFieldInstr( | 
| +        LoadFieldInstr* load = new(Z) LoadFieldInstr( | 
| receiver, | 
| Bigint::neg_offset(), | 
| -            Type::ZoneHandle(I, Type::BoolType()), | 
| +            Type::ZoneHandle(Z, Type::BoolType()), | 
| node->token_pos()); | 
| load->set_result_cid(kBoolCid); | 
| load->set_recognized_kind(kind); | 
| @@ -3408,7 +3408,7 @@ | 
| } | 
| } | 
| InlineBailout("EffectGraphVisitor::VisitNativeBodyNode"); | 
| -  NativeCallInstr* native_call = new(I) NativeCallInstr(node); | 
| +  NativeCallInstr* native_call = new(Z) NativeCallInstr(node); | 
| ReturnDefinition(native_call); | 
| } | 
|  | 
| @@ -3440,7 +3440,7 @@ | 
| if (node->value()->IsLiteralNode() || | 
| node->value()->IsLoadLocalNode() || | 
| node->value()->IsClosureNode()) { | 
| -    AddInstruction(new(I) DebugStepCheckInstr( | 
| +    AddInstruction(new(Z) DebugStepCheckInstr( | 
| node->token_pos(), RawPcDescriptors::kRuntimeCall)); | 
| } | 
|  | 
| @@ -3464,10 +3464,10 @@ | 
| ValueGraphVisitor for_instance(owner()); | 
| node->instance()->Visit(&for_instance); | 
| Append(for_instance); | 
| -  LoadFieldInstr* load = new(I) LoadFieldInstr( | 
| +  LoadFieldInstr* load = new(Z) LoadFieldInstr( | 
| for_instance.value(), | 
| &node->field(), | 
| -      AbstractType::ZoneHandle(I, node->field().type()), | 
| +      AbstractType::ZoneHandle(Z, node->field().type()), | 
| node->token_pos()); | 
| if (node->field().guarded_cid() != kIllegalCid) { | 
| if (!node->field().is_nullable() || | 
| @@ -3491,8 +3491,8 @@ | 
| Value* store_value = for_value.value(); | 
| if (Isolate::Current()->TypeChecksEnabled()) { | 
| const AbstractType& type = | 
| -        AbstractType::ZoneHandle(I, node->field().type()); | 
| -    const String& dst_name = String::ZoneHandle(I, node->field().name()); | 
| +        AbstractType::ZoneHandle(Z, node->field().type()); | 
| +    const String& dst_name = String::ZoneHandle(Z, node->field().name()); | 
| store_value = BuildAssignableValue(node->value()->token_pos(), | 
| store_value, | 
| type, | 
| @@ -3501,21 +3501,21 @@ | 
|  | 
| store_value = Bind(BuildStoreExprTemp(store_value)); | 
| GuardFieldClassInstr* guard_field_class = | 
| -      new(I) GuardFieldClassInstr(store_value, | 
| +      new(Z) GuardFieldClassInstr(store_value, | 
| node->field(), | 
| -                               I->GetNextDeoptId()); | 
| +                               isolate()->GetNextDeoptId()); | 
| AddInstruction(guard_field_class); | 
|  | 
| store_value = Bind(BuildLoadExprTemp()); | 
| GuardFieldLengthInstr* guard_field_length = | 
| -      new(I) GuardFieldLengthInstr(store_value, | 
| +      new(Z) GuardFieldLengthInstr(store_value, | 
| node->field(), | 
| -                                   I->GetNextDeoptId()); | 
| +                                   isolate()->GetNextDeoptId()); | 
| AddInstruction(guard_field_length); | 
|  | 
| store_value = Bind(BuildLoadExprTemp()); | 
| StoreInstanceFieldInstr* store = | 
| -      new(I) StoreInstanceFieldInstr(node->field(), | 
| +      new(Z) StoreInstanceFieldInstr(node->field(), | 
| for_instance.value(), | 
| store_value, | 
| kEmitStoreBarrier, | 
| @@ -3531,11 +3531,11 @@ | 
| ASSERT(node->field().value() != Object::sentinel().raw()); | 
| ASSERT(node->field().value() != Object::transition_sentinel().raw()); | 
| Definition* result = | 
| -        new(I) ConstantInstr(Instance::ZoneHandle(I, node->field().value())); | 
| +        new(Z) ConstantInstr(Instance::ZoneHandle(Z, node->field().value())); | 
| return ReturnDefinition(result); | 
| } | 
| -  Value* field_value = Bind(new(I) ConstantInstr(node->field())); | 
| -  LoadStaticFieldInstr* load = new(I) LoadStaticFieldInstr(field_value); | 
| +  Value* field_value = Bind(new(Z) ConstantInstr(node->field())); | 
| +  LoadStaticFieldInstr* load = new(Z) LoadStaticFieldInstr(field_value); | 
| ReturnDefinition(load); | 
| } | 
|  | 
| @@ -3552,7 +3552,7 @@ | 
| store_value = for_value.value(); | 
| } | 
| StoreStaticFieldInstr* store = | 
| -      new(I) StoreStaticFieldInstr(node->field(), store_value); | 
| +      new(Z) StoreStaticFieldInstr(node->field(), store_value); | 
|  | 
| if (result_is_needed) { | 
| Do(store); | 
| @@ -3578,12 +3578,12 @@ | 
| if (node->IsSuperLoad()) { | 
| // Resolve the load indexed operator in the super class. | 
| super_function = &Function::ZoneHandle( | 
| -          I, Resolver::ResolveDynamicAnyArgs(node->super_class(), | 
| +          Z, Resolver::ResolveDynamicAnyArgs(node->super_class(), | 
| Symbols::IndexToken())); | 
| if (super_function->IsNull()) { | 
| // Could not resolve super operator. Generate call noSuchMethod() of the | 
| // super class instead. | 
| -      ArgumentListNode* arguments = new(I) ArgumentListNode(node->token_pos()); | 
| +      ArgumentListNode* arguments = new(Z) ArgumentListNode(node->token_pos()); | 
| arguments->Add(node->array()); | 
| arguments->Add(node->index_expr()); | 
| StaticCallInstr* call = | 
| @@ -3598,7 +3598,7 @@ | 
| } | 
| } | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| ValueGraphVisitor for_array(owner()); | 
| node->array()->Visit(&for_array); | 
| Append(for_array); | 
| @@ -3611,7 +3611,7 @@ | 
|  | 
| if (super_function != NULL) { | 
| // Generate static call to super operator. | 
| -    StaticCallInstr* load = new(I) StaticCallInstr(node->token_pos(), | 
| +    StaticCallInstr* load = new(Z) StaticCallInstr(node->token_pos(), | 
| *super_function, | 
| Object::null_array(), | 
| arguments, | 
| @@ -3620,7 +3620,7 @@ | 
| } else { | 
| // Generate dynamic call to index operator. | 
| const intptr_t checked_argument_count = 1; | 
| -    InstanceCallInstr* load = new(I) InstanceCallInstr( | 
| +    InstanceCallInstr* load = new(Z) InstanceCallInstr( | 
| node->token_pos(), | 
| Symbols::IndexToken(), | 
| Token::kINDEX, | 
| @@ -3640,12 +3640,12 @@ | 
| if (node->IsSuperStore()) { | 
| // Resolve the store indexed operator in the super class. | 
| super_function = &Function::ZoneHandle( | 
| -        I, Resolver::ResolveDynamicAnyArgs(node->super_class(), | 
| +        Z, Resolver::ResolveDynamicAnyArgs(node->super_class(), | 
| Symbols::AssignIndexToken())); | 
| if (super_function->IsNull()) { | 
| // Could not resolve super operator. Generate call noSuchMethod() of the | 
| // super class instead. | 
| -      ArgumentListNode* arguments = new(I) ArgumentListNode(node->token_pos()); | 
| +      ArgumentListNode* arguments = new(Z) ArgumentListNode(node->token_pos()); | 
| arguments->Add(node->array()); | 
| arguments->Add(node->index_expr()); | 
| arguments->Add(node->value()); | 
| @@ -3667,7 +3667,7 @@ | 
| } | 
|  | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(3); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(3); | 
| ValueGraphVisitor for_array(owner()); | 
| node->array()->Visit(&for_array); | 
| Append(for_array); | 
| @@ -3693,7 +3693,7 @@ | 
| // Generate static call to super operator []=. | 
|  | 
| StaticCallInstr* store = | 
| -        new(I) StaticCallInstr(node->token_pos(), | 
| +        new(Z) StaticCallInstr(node->token_pos(), | 
| *super_function, | 
| Object::null_array(), | 
| arguments, | 
| @@ -3708,9 +3708,9 @@ | 
| // Generate dynamic call to operator []=. | 
| const intptr_t checked_argument_count = 3; | 
| const String& name = | 
| -        String::ZoneHandle(I, Symbols::New(Token::Str(Token::kASSIGN_INDEX))); | 
| +        String::ZoneHandle(Z, Symbols::New(Token::Str(Token::kASSIGN_INDEX))); | 
| InstanceCallInstr* store = | 
| -        new(I) InstanceCallInstr(node->token_pos(), | 
| +        new(Z) InstanceCallInstr(node->token_pos(), | 
| name, | 
| Token::kASSIGN_INDEX, | 
| arguments, | 
| @@ -3749,10 +3749,10 @@ | 
| Value* context = Bind(BuildCurrentContext()); | 
| while (n-- > 0) { | 
| context = Bind( | 
| -          new(I) LoadFieldInstr(context, | 
| +          new(Z) LoadFieldInstr(context, | 
| Context::parent_offset(), | 
| // Not an instance, no type. | 
| -                                Type::ZoneHandle(I, Type::null()), | 
| +                                Type::ZoneHandle(Z, Type::null()), | 
| Scanner::kNoSourcePos)); | 
| } | 
| Do(BuildStoreContext(context)); | 
| @@ -3779,13 +3779,13 @@ | 
| // Allocate and chain a new context (Except don't chain when at the function | 
| // entry if the function does not capture any variables from outer scopes). | 
| Value* allocated_context = | 
| -        Bind(new(I) AllocateContextInstr(node->token_pos(), | 
| +        Bind(new(Z) AllocateContextInstr(node->token_pos(), | 
| num_context_variables)); | 
| { LocalVariable* tmp_var = EnterTempLocalScope(allocated_context); | 
| if (HasContextScope() || !is_top_level_sequence) { | 
| -        Value* tmp_val = Bind(new(I) LoadLocalInstr(*tmp_var)); | 
| +        Value* tmp_val = Bind(new(Z) LoadLocalInstr(*tmp_var)); | 
| Value* parent_context = Bind(BuildCurrentContext()); | 
| -        Do(new(I) StoreInstanceFieldInstr(Context::parent_offset(), | 
| +        Do(new(Z) StoreInstanceFieldInstr(Context::parent_offset(), | 
| tmp_val, | 
| parent_context, | 
| kEmitStoreBarrier, | 
| @@ -3807,10 +3807,10 @@ | 
| if (parameter.is_captured()) { | 
| // Create a temporary local describing the original position. | 
| const String& temp_name = Symbols::TempParam(); | 
| -          LocalVariable* temp_local = new(I) LocalVariable( | 
| +          LocalVariable* temp_local = new(Z) LocalVariable( | 
| 0,  // Token index. | 
| temp_name, | 
| -              Type::ZoneHandle(I, Type::DynamicType()));  // Type. | 
| +              Type::ZoneHandle(Z, Type::DynamicType()));  // Type. | 
| temp_local->set_index(param_frame_index); | 
|  | 
| // Mark this local as captured parameter so that the optimizer | 
| @@ -3825,8 +3825,8 @@ | 
| // Write NULL to the source location to detect buggy accesses and | 
| // allow GC of passed value if it gets overwritten by a new value in | 
| // the function. | 
| -          Value* null_constant = Bind(new(I) ConstantInstr( | 
| -              Object::ZoneHandle(I, Object::null()))); | 
| +          Value* null_constant = Bind(new(Z) ConstantInstr( | 
| +              Object::ZoneHandle(Z, Object::null()))); | 
| Do(BuildStoreLocal(*temp_local, null_constant)); | 
| } | 
| } | 
| @@ -3841,7 +3841,7 @@ | 
| if (!function.IsImplicitGetterFunction() && | 
| !function.IsImplicitSetterFunction()) { | 
| CheckStackOverflowInstr* check = | 
| -          new(I) CheckStackOverflowInstr(function.token_pos(), 0); | 
| +          new(Z) CheckStackOverflowInstr(function.token_pos(), 0); | 
| // If we are inlining don't actually attach the stack check. We must still | 
| // create the stack check in order to allocate a deopt id. | 
| if (!owner()->IsInlining()) { | 
| @@ -3887,7 +3887,7 @@ | 
| (function.IsAsyncClosure() || | 
| function.IsSyncGenClosure() || | 
| function.IsAsyncGenClosure())) { | 
| -    JoinEntryInstr* preamble_end = new(I) JoinEntryInstr( | 
| +    JoinEntryInstr* preamble_end = new(Z) JoinEntryInstr( | 
| owner()->AllocateBlockId(), owner()->try_index()); | 
| ASSERT(exit() != NULL); | 
| exit()->Goto(preamble_end); | 
| @@ -3927,7 +3927,7 @@ | 
| exit_ = NULL; | 
|  | 
| LoadLocalNode* load_jump_count = | 
| -        new(I) LoadLocalNode(Scanner::kNoSourcePos, jump_var); | 
| +        new(Z) LoadLocalNode(Scanner::kNoSourcePos, jump_var); | 
| ComparisonNode* check_jump_count; | 
| const intptr_t num_await_states = owner()->await_joins()->length(); | 
|  | 
| @@ -3934,12 +3934,12 @@ | 
| LocalVariable* old_context = top_scope->LookupVariable( | 
| Symbols::AwaitContextVar(), false); | 
| for (intptr_t i = 0; i < num_await_states; i++) { | 
| -      check_jump_count = new(I) ComparisonNode( | 
| +      check_jump_count = new(Z) ComparisonNode( | 
| Scanner::kNoSourcePos, | 
| Token::kEQ, | 
| load_jump_count, | 
| -          new(I) LiteralNode( | 
| -              Scanner::kNoSourcePos, Smi::ZoneHandle(I, Smi::New(i)))); | 
| +          new(Z) LiteralNode( | 
| +              Scanner::kNoSourcePos, Smi::ZoneHandle(Z, Smi::New(i)))); | 
| TestGraphVisitor for_test(owner(), Scanner::kNoSourcePos); | 
| check_jump_count->Visit(&for_test); | 
| EffectGraphVisitor for_true(owner()); | 
| @@ -4030,7 +4030,7 @@ | 
|  | 
| if (for_try.is_open()) { | 
| JoinEntryInstr* after_try = | 
| -        new(I) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +        new(Z) JoinEntryInstr(owner()->AllocateBlockId(), | 
| original_handler_index); | 
| for_try.Goto(after_try); | 
| for_try.exit_ = after_try; | 
| @@ -4037,7 +4037,7 @@ | 
| } | 
|  | 
| JoinEntryInstr* try_entry = | 
| -      new(I) JoinEntryInstr(owner()->AllocateBlockId(), try_handler_index); | 
| +      new(Z) JoinEntryInstr(owner()->AllocateBlockId(), try_handler_index); | 
|  | 
| Goto(try_entry); | 
| AppendFragment(try_entry, for_try); | 
| @@ -4070,7 +4070,7 @@ | 
| ASSERT(!catch_block->stacktrace_var().is_captured()); | 
|  | 
| CatchBlockEntryInstr* catch_entry = | 
| -      new(I) CatchBlockEntryInstr(owner()->AllocateBlockId(), | 
| +      new(Z) CatchBlockEntryInstr(owner()->AllocateBlockId(), | 
| catch_handler_index, | 
| catch_block->handler_types(), | 
| try_handler_index, | 
| @@ -4081,7 +4081,7 @@ | 
| AppendFragment(catch_entry, for_catch); | 
|  | 
| if (for_catch.is_open()) { | 
| -    JoinEntryInstr* join = new(I) JoinEntryInstr(owner()->AllocateBlockId(), | 
| +    JoinEntryInstr* join = new(Z) JoinEntryInstr(owner()->AllocateBlockId(), | 
| original_handler_index); | 
| for_catch.Goto(join); | 
| if (is_open()) Goto(join); | 
| @@ -4105,15 +4105,15 @@ | 
| for_finally.BuildLoadLocal(catch_block->rethrow_stacktrace_var())); | 
| for_finally.PushArgument(stacktrace); | 
| for_finally.AddInstruction( | 
| -          new(I) ReThrowInstr(catch_block->token_pos(), catch_handler_index)); | 
| +          new(Z) ReThrowInstr(catch_block->token_pos(), catch_handler_index)); | 
| for_finally.CloseFragment(); | 
| } | 
| ASSERT(!for_finally.is_open()); | 
|  | 
| -    const Array& types = Array::ZoneHandle(I, Array::New(1, Heap::kOld)); | 
| -    types.SetAt(0, Type::Handle(I, Type::DynamicType())); | 
| +    const Array& types = Array::ZoneHandle(Z, Array::New(1, Heap::kOld)); | 
| +    types.SetAt(0, Type::Handle(Z, Type::DynamicType())); | 
| CatchBlockEntryInstr* finally_entry = | 
| -        new(I) CatchBlockEntryInstr(owner()->AllocateBlockId(), | 
| +        new(Z) CatchBlockEntryInstr(owner()->AllocateBlockId(), | 
| original_handler_index, | 
| types, | 
| catch_handler_index, | 
| @@ -4153,14 +4153,14 @@ | 
| *method_arguments, | 
| temp, | 
| is_super_invocation); | 
| -  const Function& no_such_method_func = Function::ZoneHandle(I, | 
| +  const Function& no_such_method_func = Function::ZoneHandle(Z, | 
| Resolver::ResolveDynamicAnyArgs(target_class, Symbols::NoSuchMethod())); | 
| // We are guaranteed to find noSuchMethod of class Object. | 
| ASSERT(!no_such_method_func.IsNull()); | 
| ZoneGrowableArray<PushArgumentInstr*>* push_arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(2); | 
| BuildPushArguments(*args, push_arguments); | 
| -  return new(I) StaticCallInstr(args_pos, | 
| +  return new(Z) StaticCallInstr(args_pos, | 
| no_such_method_func, | 
| Object::null_array(), | 
| push_arguments, | 
| @@ -4175,36 +4175,36 @@ | 
| ArgumentListNode* function_arguments, | 
| int invocation_type) { | 
| ZoneGrowableArray<PushArgumentInstr*>* arguments = | 
| -      new(I) ZoneGrowableArray<PushArgumentInstr*>(); | 
| +      new(Z) ZoneGrowableArray<PushArgumentInstr*>(); | 
| // Object receiver, actually a class literal of the unresolved method's owner. | 
| Type& type = Type::ZoneHandle( | 
| -      I, | 
| +      Z, | 
| Type::New(function_class, | 
| -                TypeArguments::Handle(I, TypeArguments::null()), | 
| +                TypeArguments::Handle(Z, TypeArguments::null()), | 
| token_pos, | 
| Heap::kOld)); | 
| type ^= ClassFinalizer::FinalizeType( | 
| function_class, type, ClassFinalizer::kCanonicalize); | 
| -  Value* receiver_value = Bind(new(I) ConstantInstr(type)); | 
| +  Value* receiver_value = Bind(new(Z) ConstantInstr(type)); | 
| arguments->Add(PushArgument(receiver_value)); | 
| // String memberName. | 
| const String& member_name = | 
| -      String::ZoneHandle(I, Symbols::New(function_name)); | 
| -  Value* member_name_value = Bind(new(I) ConstantInstr(member_name)); | 
| +      String::ZoneHandle(Z, Symbols::New(function_name)); | 
| +  Value* member_name_value = Bind(new(Z) ConstantInstr(member_name)); | 
| arguments->Add(PushArgument(member_name_value)); | 
| // Smi invocation_type. | 
| -  Value* invocation_type_value = Bind(new(I) ConstantInstr( | 
| -      Smi::ZoneHandle(I, Smi::New(invocation_type)))); | 
| +  Value* invocation_type_value = Bind(new(Z) ConstantInstr( | 
| +      Smi::ZoneHandle(Z, Smi::New(invocation_type)))); | 
| arguments->Add(PushArgument(invocation_type_value)); | 
| // List arguments. | 
| if (function_arguments == NULL) { | 
| Value* arguments_value = Bind( | 
| -        new(I) ConstantInstr(Array::ZoneHandle(I, Array::null()))); | 
| +        new(Z) ConstantInstr(Array::ZoneHandle(Z, Array::null()))); | 
| arguments->Add(PushArgument(arguments_value)); | 
| } else { | 
| ValueGraphVisitor array_val(owner()); | 
| ArrayNode* array = | 
| -        new(I) ArrayNode(token_pos, Type::ZoneHandle(I, Type::ArrayType()), | 
| +        new(Z) ArrayNode(token_pos, Type::ZoneHandle(Z, Type::ArrayType()), | 
| function_arguments->nodes()); | 
| array->Visit(&array_val); | 
| Append(array_val); | 
| @@ -4211,8 +4211,8 @@ | 
| arguments->Add(PushArgument(array_val.value())); | 
| } | 
| // List argumentNames. | 
| -  ConstantInstr* cinstr = new(I) ConstantInstr( | 
| -      (function_arguments == NULL) ? Array::ZoneHandle(I, Array::null()) | 
| +  ConstantInstr* cinstr = new(Z) ConstantInstr( | 
| +      (function_arguments == NULL) ? Array::ZoneHandle(Z, Array::null()) | 
| : function_arguments->names()); | 
| Value* argument_names_value = Bind(cinstr); | 
| arguments->Add(PushArgument(argument_names_value)); | 
| @@ -4219,21 +4219,21 @@ | 
|  | 
| // List existingArgumentNames. | 
| Value* existing_argument_names_value = | 
| -      Bind(new(I) ConstantInstr(Array::ZoneHandle(I, Array::null()))); | 
| +      Bind(new(Z) ConstantInstr(Array::ZoneHandle(Z, Array::null()))); | 
| arguments->Add(PushArgument(existing_argument_names_value)); | 
| // Resolve and call NoSuchMethodError._throwNew. | 
| -  const Library& core_lib = Library::Handle(I, Library::CoreLibrary()); | 
| +  const Library& core_lib = Library::Handle(Z, Library::CoreLibrary()); | 
| const Class& cls = Class::Handle( | 
| -      I, core_lib.LookupClass(Symbols::NoSuchMethodError())); | 
| +      Z, core_lib.LookupClass(Symbols::NoSuchMethodError())); | 
| ASSERT(!cls.IsNull()); | 
| const Function& func = Function::ZoneHandle( | 
| -      I, | 
| +      Z, | 
| Resolver::ResolveStatic(cls, | 
| Library::PrivateCoreLibName(Symbols::ThrowNew()), | 
| arguments->length(), | 
| Object::null_array())); | 
| ASSERT(!func.IsNull()); | 
| -  return new(I) StaticCallInstr(token_pos, | 
| +  return new(Z) StaticCallInstr(token_pos, | 
| func, | 
| Object::null_array(),  // No names. | 
| arguments, | 
| @@ -4245,7 +4245,7 @@ | 
| if (node->exception()->IsLiteralNode() || | 
| node->exception()->IsLoadLocalNode() || | 
| node->exception()->IsClosureNode()) { | 
| -    AddInstruction(new(I) DebugStepCheckInstr( | 
| +    AddInstruction(new(Z) DebugStepCheckInstr( | 
| node->token_pos(), RawPcDescriptors::kRuntimeCall)); | 
| } | 
| ValueGraphVisitor for_exception(owner()); | 
| @@ -4254,13 +4254,13 @@ | 
| PushArgument(for_exception.value()); | 
| Instruction* instr = NULL; | 
| if (node->stacktrace() == NULL) { | 
| -    instr = new(I) ThrowInstr(node->token_pos()); | 
| +    instr = new(Z) ThrowInstr(node->token_pos()); | 
| } else { | 
| ValueGraphVisitor for_stack_trace(owner()); | 
| node->stacktrace()->Visit(&for_stack_trace); | 
| Append(for_stack_trace); | 
| PushArgument(for_stack_trace.value()); | 
| -    instr = new(I) ReThrowInstr(node->token_pos(), owner()->catch_try_index()); | 
| +    instr = new(Z) ReThrowInstr(node->token_pos(), owner()->catch_try_index()); | 
| } | 
| AddInstruction(instr); | 
| } | 
| @@ -4277,8 +4277,8 @@ | 
| // so that the fragment is not closed in the middle of an expression. | 
| void ValueGraphVisitor::VisitThrowNode(ThrowNode* node) { | 
| BuildThrowNode(node); | 
| -  ReturnDefinition(new(I) ConstantInstr( | 
| -      Instance::ZoneHandle(I, Instance::null()))); | 
| +  ReturnDefinition(new(Z) ConstantInstr( | 
| +      Instance::ZoneHandle(Z, Instance::null()))); | 
| } | 
|  | 
|  | 
| @@ -4295,7 +4295,7 @@ | 
| BuildRestoreContext(node->context_var()); | 
|  | 
| JoinEntryInstr* finally_entry = | 
| -      new(I) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| +      new(Z) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| EffectGraphVisitor for_finally_block(owner()); | 
| node->finally_block()->Visit(&for_finally_block); | 
|  | 
| @@ -4305,7 +4305,7 @@ | 
|  | 
| if (for_finally_block.is_open()) { | 
| JoinEntryInstr* after_finally = | 
| -        new(I) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| +        new(Z) JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 
| for_finally_block.Goto(after_finally); | 
| for_finally_block.exit_ = after_finally; | 
| } | 
| @@ -4325,10 +4325,10 @@ | 
| AstPrinter::PrintFunctionScope(parsed_function()); | 
| } | 
| TargetEntryInstr* normal_entry = | 
| -      new(I) TargetEntryInstr(AllocateBlockId(), | 
| +      new(Z) TargetEntryInstr(AllocateBlockId(), | 
| CatchClauseNode::kInvalidTryIndex); | 
| graph_entry_ = | 
| -      new(I) GraphEntryInstr(parsed_function(), normal_entry, osr_id_); | 
| +      new(Z) GraphEntryInstr(parsed_function(), normal_entry, osr_id_); | 
| EffectGraphVisitor for_effect(this); | 
| parsed_function().node_sequence()->Visit(&for_effect); | 
| AppendFragment(normal_entry, for_effect); | 
| @@ -4343,7 +4343,7 @@ | 
| } | 
|  | 
| FlowGraph* graph = | 
| -      new(I) FlowGraph(parsed_function(), graph_entry_, last_used_block_id_); | 
| +      new(Z) FlowGraph(parsed_function(), graph_entry_, last_used_block_id_); | 
| return graph; | 
| } | 
|  | 
| @@ -4350,8 +4350,7 @@ | 
|  | 
| void FlowGraphBuilder::PruneUnreachable() { | 
| ASSERT(osr_id_ != Isolate::kNoDeoptId); | 
| -  Zone* zone = parsed_function().zone(); | 
| -  BitVector* block_marks = new(zone) BitVector(zone, last_used_block_id_ + 1); | 
| +  BitVector* block_marks = new(Z) BitVector(Z, last_used_block_id_ + 1); | 
| bool found = graph_entry_->PruneUnreachable(this, graph_entry_, NULL, osr_id_, | 
| block_marks); | 
| ASSERT(found); | 
|  |