Chromium Code Reviews| Index: src/preparser.cc |
| diff --git a/src/preparser.cc b/src/preparser.cc |
| index b1541f616afe133554881e99aec4f71a9f5e45e0..b1e6ad8309661e590156c7c15df1235c44cb8729 100644 |
| --- a/src/preparser.cc |
| +++ b/src/preparser.cc |
| @@ -102,8 +102,8 @@ PreParserExpression PreParserTraits::ParseFunctionLiteral( |
| PreParser::PreParseResult PreParser::PreParseLazyFunction( |
| - LanguageMode language_mode, FunctionKind kind, ParserRecorder* log, |
| - Scanner::BookmarkScope* bookmark) { |
| + LanguageMode language_mode, FunctionKind kind, bool has_simple_parameters, |
| + ParserRecorder* log, Scanner::BookmarkScope* bookmark) { |
| log_ = log; |
| // Lazy functions always have trivial outer scopes (no with/catch scopes). |
| Scope* top_scope = NewScope(scope_, SCRIPT_SCOPE); |
| @@ -113,6 +113,7 @@ PreParser::PreParseResult PreParser::PreParseLazyFunction( |
| scope_->SetLanguageMode(language_mode); |
| Scope* function_scope = NewScope( |
| scope_, IsArrowFunction(kind) ? ARROW_SCOPE : FUNCTION_SCOPE, kind); |
| + if (!has_simple_parameters) function_scope->SetHasNonSimpleParameters(); |
| PreParserFactory function_factory(NULL); |
| FunctionState function_state(&function_state_, &scope_, function_scope, kind, |
| &function_factory); |
| @@ -251,15 +252,35 @@ void PreParser::ParseStatementList(int end_token, bool* ok, |
| } |
| if (directive_prologue) { |
| - if (statement.IsUseStrictLiteral()) { |
| + bool use_strict_found = statement.IsUseStrictLiteral(); |
| + bool use_strong_found = |
| + statement.IsUseStrongLiteral() && allow_strong_mode(); |
| + |
| + if (use_strict_found) { |
| scope_->SetLanguageMode( |
| static_cast<LanguageMode>(scope_->language_mode() | STRICT)); |
| - } else if (statement.IsUseStrongLiteral() && allow_strong_mode()) { |
| + } else if (use_strong_found) { |
| scope_->SetLanguageMode(static_cast<LanguageMode>( |
| scope_->language_mode() | STRONG)); |
| } else if (!statement.IsStringLiteral()) { |
| directive_prologue = false; |
| } |
| + |
| + if (use_strict_found || use_strong_found) { |
| + if (!scope_->HasSimpleParameters()) { |
|
rossberg
2015/08/24 13:11:08
Nit: merge conditions
conradw
2015/08/25 11:31:20
Done.
|
| + // A block declaration scope as a child scope of a function scope |
|
rossberg
2015/08/24 13:11:08
Not sure how the comment relates to the code. Whic
conradw
2015/08/25 11:31:20
I think this is referring to HasSimpleParameters l
|
| + // indicates that a function has a non-simple parameter list. |
| + // TC39 deemed "use strict" directives to be an error in this case, |
| + // on 29/7/2015. https://goo.gl/ueA7Ln |
| + // |
| + // In V8, this also applies to "use strong " directives. |
| + PreParserTraits::ReportMessageAt( |
| + token_loc, MessageTemplate::kIllegalLanguageModeDirective, |
| + use_strict_found ? "use strict" : "use strong"); |
| + *ok = false; |
| + return; |
| + } |
| + } |
| } |
| // If we're allowed to reset to a bookmark, we will do so when we see a long |
| @@ -1057,7 +1078,7 @@ PreParser::Expression PreParser::ParseFunctionLiteral( |
| Expect(Token::LPAREN, CHECK_OK); |
| int start_position = scanner()->location().beg_pos; |
| function_scope->set_start_position(start_position); |
| - PreParserFormalParameters formals(nullptr); |
| + PreParserFormalParameters formals(function_scope); |
| ParseFormalParameterList(&formals, &formals_classifier, CHECK_OK); |
| Expect(Token::RPAREN, CHECK_OK); |
| int formals_end_position = scanner()->location().end_pos; |