Commit 1992d72b authored by jochen's avatar jochen Committed by Commit bot

Don't reuse the name scope for multiple variables in DoParseLazy

R=marja@chromium.org,verwaest@chromium.org
BUG=

Review-Url: https://codereview.chromium.org/2293803002
Cr-Commit-Position: refs/heads/master@{#39008}
parent 1ceb9aec
...@@ -670,13 +670,13 @@ FunctionLiteral* Parser::DoParseProgram(ParseInfo* info) { ...@@ -670,13 +670,13 @@ FunctionLiteral* Parser::DoParseProgram(ParseInfo* info) {
FunctionLiteral* result = NULL; FunctionLiteral* result = NULL;
{ {
Scope* outer = original_scope_; Scope* outer = original_scope_;
DCHECK_NOT_NULL(outer);
// If there's a chance that there's a reference to global 'this', predeclare // If there's a chance that there's a reference to global 'this', predeclare
// it as a dynamic global on the script scope. // it as a dynamic global on the script scope.
if (outer->GetReceiverScope()->is_script_scope()) { if (outer->GetReceiverScope()->is_script_scope()) {
info->script_scope()->DeclareDynamicGlobal( info->script_scope()->DeclareDynamicGlobal(
ast_value_factory()->this_string(), Variable::THIS); ast_value_factory()->this_string(), Variable::THIS);
} }
DCHECK(outer);
if (info->is_eval()) { if (info->is_eval()) {
if (!outer->is_script_scope() || is_strict(info->language_mode())) { if (!outer->is_script_scope() || is_strict(info->language_mode())) {
parsing_mode = PARSE_EAGERLY; parsing_mode = PARSE_EAGERLY;
...@@ -839,17 +839,17 @@ FunctionLiteral* Parser::DoParseLazy(ParseInfo* info, ...@@ -839,17 +839,17 @@ FunctionLiteral* Parser::DoParseLazy(ParseInfo* info,
{ {
// Parse the function literal. // Parse the function literal.
Scope* scope = original_scope_; Scope* outer = original_scope_;
DCHECK(scope); DCHECK(outer);
// If there's a chance that there's a reference to global 'this', predeclare // If there's a chance that there's a reference to global 'this', predeclare
// it as a dynamic global on the script scope. // it as a dynamic global on the script scope.
if (info->is_arrow() && scope->GetReceiverScope()->is_script_scope()) { if (info->is_arrow() && outer->GetReceiverScope()->is_script_scope()) {
info->script_scope()->DeclareDynamicGlobal( info->script_scope()->DeclareDynamicGlobal(
ast_value_factory()->this_string(), Variable::THIS); ast_value_factory()->this_string(), Variable::THIS);
} }
FunctionState function_state(&function_state_, &scope_state_, scope, FunctionState function_state(&function_state_, &scope_state_, outer,
info->function_kind()); info->function_kind());
DCHECK(is_sloppy(scope->language_mode()) || DCHECK(is_sloppy(outer->language_mode()) ||
is_strict(info->language_mode())); is_strict(info->language_mode()));
FunctionLiteral::FunctionType function_type = ComputeFunctionType(info); FunctionLiteral::FunctionType function_type = ComputeFunctionType(info);
bool ok = true; bool ok = true;
...@@ -927,7 +927,7 @@ FunctionLiteral* Parser::DoParseLazy(ParseInfo* info, ...@@ -927,7 +927,7 @@ FunctionLiteral* Parser::DoParseLazy(ParseInfo* info,
} }
} }
} else if (info->is_default_constructor()) { } else if (info->is_default_constructor()) {
DCHECK_EQ(this->scope(), scope); DCHECK_EQ(scope(), outer);
result = DefaultConstructor( result = DefaultConstructor(
raw_name, IsSubclassConstructor(info->function_kind()), raw_name, IsSubclassConstructor(info->function_kind()),
info->start_position(), info->end_position(), info->language_mode()); info->start_position(), info->end_position(), info->language_mode());
......
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