Commit 1c74ca66 authored by ishell's avatar ishell Committed by Commit bot

When adding constant string with something unknown, assume it's a string.

Review URL: https://codereview.chromium.org/1122823002

Cr-Commit-Position: refs/heads/master@{#28221}
parent 728f0af6
...@@ -10664,14 +10664,29 @@ HValue* HGraphBuilder::BuildBinaryOperation( ...@@ -10664,14 +10664,29 @@ HValue* HGraphBuilder::BuildBinaryOperation(
Maybe<int> fixed_right_arg, Maybe<int> fixed_right_arg,
HAllocationMode allocation_mode, HAllocationMode allocation_mode,
LanguageMode language_mode) { LanguageMode language_mode) {
Representation left_rep = RepresentationFor(left_type); bool maybe_string_add = false;
Representation right_rep = RepresentationFor(right_type); if (op == Token::ADD) {
// If we are adding constant string with something for which we don't have
// a feedback yet, assume that it's also going to be a string and don't
// generate deopt instructions.
if (!left_type->IsInhabited() && right->IsConstant() &&
HConstant::cast(right)->HasStringValue()) {
left_type = Type::String();
}
if (!right_type->IsInhabited() && left->IsConstant() &&
HConstant::cast(left)->HasStringValue()) {
right_type = Type::String();
}
bool maybe_string_add = op == Token::ADD && maybe_string_add = (left_type->Maybe(Type::String()) ||
(left_type->Maybe(Type::String()) ||
left_type->Maybe(Type::Receiver()) || left_type->Maybe(Type::Receiver()) ||
right_type->Maybe(Type::String()) || right_type->Maybe(Type::String()) ||
right_type->Maybe(Type::Receiver())); right_type->Maybe(Type::Receiver()));
}
Representation left_rep = RepresentationFor(left_type);
Representation right_rep = RepresentationFor(right_type);
if (!left_type->IsInhabited()) { if (!left_type->IsInhabited()) {
Add<HDeoptimize>( Add<HDeoptimize>(
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment