| Index: runtime/vm/flow_graph_optimizer.cc | 
| =================================================================== | 
| --- runtime/vm/flow_graph_optimizer.cc	(revision 29114) | 
| +++ runtime/vm/flow_graph_optimizer.cc	(working copy) | 
| @@ -6410,79 +6410,8 @@ | 
|  | 
|  | 
| void ConstantPropagator::VisitStringInterpolate(StringInterpolateInstr* instr) { | 
| -  // TODO(srdjan): Remove the code below and enable constant folding once | 
| -  // issue resolved. | 
| SetValue(instr, non_constant_); | 
| return; | 
| - | 
| -  if (IsNonConstant(instr->constant_value())) { | 
| -    // Do not bother with costly analysis if we already know that the | 
| -    // instruction is not a constant. | 
| -    SetValue(instr, non_constant_); | 
| -    return; | 
| -  } | 
| -  // If all inputs are constant strings, numbers, booleans or null, then | 
| -  // constant fold. | 
| -  // TODO(srdjan): Also constant fold an interval of constant arguments. | 
| -  //   v2 <- CreateArray(v0) | 
| -  //   StoreIndexed(v2, v3, v4)   -- v3:constant index, v4: value. | 
| -  //   .. | 
| -  //   v8 <- StringInterpolate(v2) | 
| -  CreateArrayInstr* create_array = | 
| -      instr->value()->definition()->AsCreateArray(); | 
| -  ASSERT(create_array != NULL); | 
| - | 
| -  // Check if the string interpolation has only constant inputs. | 
| -  for (Value::Iterator it(create_array->input_use_list()); | 
| -       !it.Done(); | 
| -       it.Advance()) { | 
| -    Instruction* curr = it.Current()->instruction(); | 
| -    if (curr != instr) { | 
| -      StoreIndexedInstr* store = curr->AsStoreIndexed(); | 
| -      ASSERT(store != NULL); | 
| -      const Object& value = store->value()->definition()->constant_value(); | 
| -      if (IsNonConstant(value)) { | 
| -        SetValue(instr, non_constant_); | 
| -        return; | 
| -      } else if (IsUnknown(value)) { | 
| -        ASSERT(IsUnknown(instr->constant_value())); | 
| -        return; | 
| -      } | 
| -    } | 
| -  } | 
| -  // Interpolate string at compile time. | 
| -  const Array& value_arr = | 
| -      Array::Handle(Array::New(create_array->num_elements())); | 
| -  // Build array of literal values to interpolate. | 
| -  for (Value::Iterator it(create_array->input_use_list()); | 
| -       !it.Done(); | 
| -       it.Advance()) { | 
| -    Instruction* curr = it.Current()->instruction(); | 
| -    // Skip StringInterpolateInstr. | 
| -    if (curr != instr) { | 
| -      StoreIndexedInstr* store = curr->AsStoreIndexed(); | 
| -      ASSERT(store != NULL); | 
| -      Value* index_value = store->index(); | 
| -      ASSERT(index_value->BindsToConstant() && index_value->IsSmiValue()); | 
| -      const intptr_t ix = Smi::Cast(index_value->BoundConstant()).Value(); | 
| -      ASSERT(IsConstant(store->value()->definition()->constant_value())); | 
| -      value_arr.SetAt(ix, store->value()->definition()->constant_value()); | 
| -    } | 
| -  } | 
| -  // Build argument array to pass to the interpolation function. | 
| -  const Array& interpolate_arg = Array::Handle(Array::New(1)); | 
| -  interpolate_arg.SetAt(0, value_arr); | 
| -  // Call interpolation function. | 
| -  String& concatenated = String::ZoneHandle(); | 
| -  concatenated ^= | 
| -      DartEntry::InvokeFunction(instr->CallFunction(), interpolate_arg); | 
| -  if (concatenated.IsUnhandledException()) { | 
| -    SetValue(instr, non_constant_); | 
| -    return; | 
| -  } | 
| - | 
| -  concatenated = Symbols::New(concatenated); | 
| -  SetValue(instr, concatenated); | 
| } | 
|  | 
|  | 
| @@ -7258,16 +7187,6 @@ | 
| ConstantInstr* constant = graph_->GetConstant(defn->constant_value()); | 
| defn->ReplaceUsesWith(constant); | 
| i.RemoveCurrentFromGraph(); | 
| -        if (defn->IsStringInterpolate()) { | 
| -          CreateArrayInstr* create_array = defn->AsStringInterpolate()-> | 
| -              value()->definition()->AsCreateArray(); | 
| -          for (Value* use = create_array->input_use_list(); | 
| -              use != NULL; | 
| -              use = create_array->input_use_list()) { | 
| -            use->instruction()->RemoveFromGraph(); | 
| -          } | 
| -          create_array->RemoveFromGraph(); | 
| -        } | 
| } | 
| } | 
|  | 
|  |