Remove is_parenthesized bit from Expression and PreParserExpression

This bit was ostensibly being used to provide appropriate syntax
errors for invalid destructuring assignment patterns, but adding a
single call to RecordPatternError() (in place of
BindingPatternUnexpectedToken()) seems to have replaced the need for it.

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

Cr-Commit-Position: refs/heads/master@{#33750}
This commit is contained in:
adamk 2016-02-04 10:53:47 -08:00 committed by Commit bot
parent 3d56b0d7c0
commit 1c318a9e4c
3 changed files with 4 additions and 25 deletions

View File

@ -376,14 +376,6 @@ class Expression : public AstNode {
BailoutId id() const { return BailoutId(local_id(0)); } BailoutId id() const { return BailoutId(local_id(0)); }
TypeFeedbackId test_id() const { return TypeFeedbackId(local_id(1)); } TypeFeedbackId test_id() const { return TypeFeedbackId(local_id(1)); }
// Parenthesized expressions in the form `( Expression )`.
void set_is_parenthesized() {
bit_field_ = ParenthesizedField::update(bit_field_, true);
}
bool is_parenthesized() const {
return ParenthesizedField::decode(bit_field_);
}
protected: protected:
Expression(Zone* zone, int pos) Expression(Zone* zone, int pos)
: AstNode(pos), : AstNode(pos),
@ -406,8 +398,6 @@ class Expression : public AstNode {
int base_id_; int base_id_;
Bounds bounds_; Bounds bounds_;
class ToBooleanTypesField : public BitField16<uint16_t, 0, 9> {}; class ToBooleanTypesField : public BitField16<uint16_t, 0, 9> {};
class ParenthesizedField
: public BitField16<bool, ToBooleanTypesField::kNext, 1> {};
uint16_t bit_field_; uint16_t bit_field_;
// Ends with 16-bit field; deriving classes in turn begin with // Ends with 16-bit field; deriving classes in turn begin with
// 16-bit fields for optimum packing efficiency. // 16-bit fields for optimum packing efficiency.

View File

@ -1312,7 +1312,9 @@ ParserBase<Traits>::ParsePrimaryExpression(ExpressionClassifier* classifier,
if (!classifier->is_valid_binding_pattern()) { if (!classifier->is_valid_binding_pattern()) {
ArrowFormalParametersUnexpectedToken(classifier); ArrowFormalParametersUnexpectedToken(classifier);
} }
BindingPatternUnexpectedToken(classifier); classifier->RecordPatternError(scanner()->peek_location(),
MessageTemplate::kUnexpectedToken,
Token::String(Token::LPAREN));
Consume(Token::LPAREN); Consume(Token::LPAREN);
if (Check(Token::RPAREN)) { if (Check(Token::RPAREN)) {
// ()=>x. The continuation that looks for the => is in // ()=>x. The continuation that looks for the => is in
@ -1356,9 +1358,6 @@ ParserBase<Traits>::ParsePrimaryExpression(ExpressionClassifier* classifier,
ExpressionT expr = this->ParseExpression(true, kIsPossibleArrowFormals, ExpressionT expr = this->ParseExpression(true, kIsPossibleArrowFormals,
classifier, CHECK_OK); classifier, CHECK_OK);
Expect(Token::RPAREN, CHECK_OK); Expect(Token::RPAREN, CHECK_OK);
if (peek() != Token::ARROW) {
expr->set_is_parenthesized();
}
return expr; return expr;
} }
@ -2025,8 +2024,7 @@ ParserBase<Traits>::ParseAssignmentExpression(bool accept_IN, int flags,
ExpressionClassifier::CoverInitializedNameProduction); ExpressionClassifier::CoverInitializedNameProduction);
bool maybe_pattern = bool maybe_pattern =
(expression->IsObjectLiteral() || expression->IsArrayLiteral()) && expression->IsObjectLiteral() || expression->IsArrayLiteral();
!expression->is_parenthesized();
if (!Token::IsAssignmentOp(peek())) { if (!Token::IsAssignmentOp(peek())) {
// Parsed conditional expression only (no assignment). // Parsed conditional expression only (no assignment).
@ -3311,9 +3309,6 @@ void ParserBase<Traits>::CheckDestructuringElement(
const Scanner::Location location(begin, end); const Scanner::Location location(begin, end);
if (expression->IsArrayLiteral() || expression->IsObjectLiteral() || if (expression->IsArrayLiteral() || expression->IsObjectLiteral() ||
expression->IsAssignment()) { expression->IsAssignment()) {
if (expression->is_parenthesized()) {
classifier->RecordPatternError(location, message);
}
return; return;
} }

View File

@ -279,12 +279,6 @@ class PreParserExpression {
int position() const { return RelocInfo::kNoPosition; } int position() const { return RelocInfo::kNoPosition; }
void set_function_token_position(int position) {} void set_function_token_position(int position) {}
// Parenthesized expressions in the form `( Expression )`.
void set_is_parenthesized() {
code_ = ParenthesizedField::update(code_, true);
}
bool is_parenthesized() const { return ParenthesizedField::decode(code_); }
private: private:
enum Type { enum Type {
kExpression, kExpression,