Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(86)

Unified Diff: src/parsing/preparser.h

Issue 1871923003: Add parsing for ambient declarations (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@types-devel
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: src/parsing/preparser.h
diff --git a/src/parsing/preparser.h b/src/parsing/preparser.h
index 5ceb6c8b7df00db914b883fcd4e2ab012de04791..d2d78b8292b9a527f2e6e5b214314fcef304afe9 100644
--- a/src/parsing/preparser.h
+++ b/src/parsing/preparser.h
@@ -1219,7 +1219,7 @@ class PreParserTraits {
PreParserExpression ParseClassLiteral(PreParserIdentifier name,
Scanner::Location class_name_location,
bool name_is_strict_reserved, int pos,
- bool* ok);
+ bool ambient, bool* ok);
PreParserExpressionList PrepareSpreadArguments(PreParserExpressionList list) {
return list;
@@ -1310,7 +1310,7 @@ class PreParser : public ParserBase<PreParserTraits> {
&factory);
bool ok = true;
int start_position = scanner()->peek_location().beg_pos;
- ParseStatementList(Token::EOS, &ok);
+ ParseStatementList(Token::EOS, true, &ok);
if (stack_overflow()) return kPreParseStackOverflow;
if (!ok) {
ReportUnexpectedToken(scanner()->current_token());
@@ -1350,25 +1350,25 @@ class PreParser : public ParserBase<PreParserTraits> {
// which is set to false if parsing failed; it is unchanged otherwise.
// By making the 'exception handling' explicit, we are forced to check
// for failure at the call sites.
- Statement ParseStatementListItem(bool* ok);
- void ParseStatementList(int end_token, bool* ok,
+ Statement ParseStatementListItem(bool top_level, bool* ok);
+ void ParseStatementList(int end_token, bool top_level, bool* ok,
Scanner::BookmarkScope* bookmark = nullptr);
Statement ParseStatement(AllowLabelledFunctionStatement allow_function,
bool* ok);
Statement ParseSubStatement(AllowLabelledFunctionStatement allow_function,
bool* ok);
Statement ParseScopedStatement(bool legacy, bool* ok);
- Statement ParseFunctionDeclaration(bool* ok);
- Statement ParseClassDeclaration(bool* ok);
+ Statement ParseFunctionDeclaration(bool ambient, bool* ok);
+ Statement ParseClassDeclaration(bool ambient, bool* ok);
Statement ParseBlock(bool* ok);
Statement ParseVariableStatement(VariableDeclarationContext var_context,
- bool* ok);
+ bool ambient, bool* ok);
Statement ParseVariableDeclarations(VariableDeclarationContext var_context,
int* num_decl, bool* is_lexical,
bool* is_binding_pattern,
Scanner::Location* first_initializer_loc,
Scanner::Location* bindings_loc,
- bool* ok);
+ bool ambient, bool* ok);
Statement ParseExpressionOrLabelledStatement(
AllowLabelledFunctionStatement allow_function, bool* ok);
Statement ParseIfStatement(bool* ok);
@@ -1408,7 +1408,7 @@ class PreParser : public ParserBase<PreParserTraits> {
PreParserExpression ParseClassLiteral(PreParserIdentifier name,
Scanner::Location class_name_location,
bool name_is_strict_reserved, int pos,
- bool* ok);
+ bool ambient, bool* ok);
};
@@ -1485,7 +1485,7 @@ PreParserStatementList PreParser::ParseEagerFunctionBody(
FunctionLiteral::FunctionType function_type, bool* ok) {
ParsingModeScope parsing_mode(this, PARSE_EAGERLY);
- ParseStatementList(Token::RBRACE, ok);
+ ParseStatementList(Token::RBRACE, false, ok);
if (!*ok) return PreParserStatementList();
Expect(Token::RBRACE, ok);

Powered by Google App Engine
This is Rietveld 408576698