If we have a unary & that takes the address of a variable, do
not force the variable to escape if the unary & does not
escape.
From-SVN: r223100
if (this->op_ == OPERATOR_AND)
{
- if (this->expr_->var_expression() != NULL)
+ // If this->escapes_ is false at this point, then it was set to
+ // false by an explicit call to set_does_not_escape, and the
+ // value does not escape. If this->escapes_ is true, we may be
+ // able to set it to false if taking the address of a variable
+ // that does not escape.
+ if (this->escapes_ && this->expr_->var_expression() != NULL)
{
Named_object* var = this->expr_->var_expression()->named_object();
if (var->is_variable())