From 98286a4551d7a01d6db4295e61893b8439bb377f Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 24 Aug 2006 05:02:11 +0000 Subject: [PATCH] Allow expression actions to fail llvm-svn: 38947 --- clang/AST/Sema.cpp | 80 +++++++++++++++--------------- clang/Sema/Sema.cpp | 80 +++++++++++++++--------------- clang/include/clang/Parse/Action.h | 45 +++++++++-------- 3 files changed, 103 insertions(+), 102 deletions(-) diff --git a/clang/AST/Sema.cpp b/clang/AST/Sema.cpp index 1ba92e1ba173..7711d183281f 100644 --- a/clang/AST/Sema.cpp +++ b/clang/AST/Sema.cpp @@ -42,39 +42,39 @@ public: // Expression Parsing Callbacks. // Primary Expressions. - virtual ExprTy *ParseSimplePrimaryExpr(const LexerToken &Tok); - virtual ExprTy *ParseIntegerConstant(const LexerToken &Tok); - virtual ExprTy *ParseFloatingConstant(const LexerToken &Tok); - virtual ExprTy *ParseParenExpr(SourceLocation L, SourceLocation R, - ExprTy *Val); + virtual ExprResult ParseSimplePrimaryExpr(const LexerToken &Tok); + virtual ExprResult ParseIntegerConstant(const LexerToken &Tok); + virtual ExprResult ParseFloatingConstant(const LexerToken &Tok); + virtual ExprResult ParseParenExpr(SourceLocation L, SourceLocation R, + ExprTy *Val); // Binary/Unary Operators. 'Tok' is the token for the operator. - virtual ExprTy *ParseUnaryOp(const LexerToken &Tok, ExprTy *Input); - virtual ExprTy *ParsePostfixUnaryOp(const LexerToken &Tok, ExprTy *Input); + virtual ExprResult ParseUnaryOp(const LexerToken &Tok, ExprTy *Input); + virtual ExprResult ParsePostfixUnaryOp(const LexerToken &Tok, ExprTy *Input); - virtual ExprTy *ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, - ExprTy *Idx, SourceLocation RLoc); - virtual ExprTy *ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, - tok::TokenKind OpKind, - SourceLocation MemberLoc, - IdentifierInfo &Member); + virtual ExprResult ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, + ExprTy *Idx, SourceLocation RLoc); + virtual ExprResult ParseMemberReferenceExpr(ExprTy *Base,SourceLocation OpLoc, + tok::TokenKind OpKind, + SourceLocation MemberLoc, + IdentifierInfo &Member); /// ParseCallExpr - Handle a call to Fn with the specified array of arguments. /// This provides the location of the left/right parens and a list of comma /// locations. - virtual ExprTy *ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, - ExprTy **Args, unsigned NumArgs, - SourceLocation *CommaLocs, - SourceLocation RParenLoc); + virtual ExprResult ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, + ExprTy **Args, unsigned NumArgs, + SourceLocation *CommaLocs, + SourceLocation RParenLoc); - virtual ExprTy *ParseBinOp(const LexerToken &Tok, ExprTy *LHS, ExprTy *RHS); + virtual ExprResult ParseBinOp(const LexerToken &Tok, ExprTy *LHS,ExprTy *RHS); /// ParseConditionalOp - Parse a ?: operation. Note that 'LHS' may be null /// in the case of a the GNU conditional expr extension. - virtual ExprTy *ParseConditionalOp(SourceLocation QuestionLoc, - SourceLocation ColonLoc, - ExprTy *Cond, ExprTy *LHS, ExprTy *RHS); + virtual ExprResult ParseConditionalOp(SourceLocation QuestionLoc, + SourceLocation ColonLoc, + ExprTy *Cond, ExprTy *LHS, ExprTy *RHS); }; } // end anonymous namespace @@ -123,7 +123,7 @@ void ASTBuilder::PopScope(SourceLocation Loc, Scope *S) { // Expression Parsing Callbacks. //===--------------------------------------------------------------------===// -ASTBuilder::ExprTy *ASTBuilder::ParseSimplePrimaryExpr(const LexerToken &Tok) { +Action::ExprResult ASTBuilder::ParseSimplePrimaryExpr(const LexerToken &Tok) { switch (Tok.getKind()) { default: assert(0 && "Unknown simple primary expr!"); @@ -142,16 +142,16 @@ ASTBuilder::ExprTy *ASTBuilder::ParseSimplePrimaryExpr(const LexerToken &Tok) { } } -ASTBuilder::ExprTy *ASTBuilder::ParseIntegerConstant(const LexerToken &Tok) { +Action::ExprResult ASTBuilder::ParseIntegerConstant(const LexerToken &Tok) { return new IntegerConstant(); } -ASTBuilder::ExprTy *ASTBuilder::ParseFloatingConstant(const LexerToken &Tok) { +Action::ExprResult ASTBuilder::ParseFloatingConstant(const LexerToken &Tok) { return new FloatingConstant(); } -ASTBuilder::ExprTy *ASTBuilder::ParseParenExpr(SourceLocation L, - SourceLocation R, - ExprTy *Val) { +Action::ExprResult ASTBuilder::ParseParenExpr(SourceLocation L, + SourceLocation R, + ExprTy *Val) { // FIXME: This is obviously just for testing. ((Expr*)Val)->dump(); if (!FullLocInfo) return Val; @@ -160,8 +160,8 @@ ASTBuilder::ExprTy *ASTBuilder::ParseParenExpr(SourceLocation L, } // Unary Operators. 'Tok' is the token for the operator. -ASTBuilder::ExprTy *ASTBuilder::ParseUnaryOp(const LexerToken &Tok, - ExprTy *Input) { +Action::ExprResult ASTBuilder::ParseUnaryOp(const LexerToken &Tok, + ExprTy *Input) { UnaryOperator::Opcode Opc; switch (Tok.getKind()) { default: assert(0 && "Unknown unary op!"); @@ -183,8 +183,8 @@ ASTBuilder::ExprTy *ASTBuilder::ParseUnaryOp(const LexerToken &Tok, return new UnaryOperatorLOC(Tok.getLocation(), (Expr*)Input, Opc); } -ASTBuilder::ExprTy *ASTBuilder::ParsePostfixUnaryOp(const LexerToken &Tok, - ExprTy *Input) { +Action::ExprResult ASTBuilder::ParsePostfixUnaryOp(const LexerToken &Tok, + ExprTy *Input) { UnaryOperator::Opcode Opc; switch (Tok.getKind()) { default: assert(0 && "Unknown unary op!"); @@ -198,7 +198,7 @@ ASTBuilder::ExprTy *ASTBuilder::ParsePostfixUnaryOp(const LexerToken &Tok, return new UnaryOperatorLOC(Tok.getLocation(), (Expr*)Input, Opc); } -ASTBuilder::ExprTy *ASTBuilder:: +Action::ExprResult ASTBuilder:: ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, ExprTy *Idx, SourceLocation RLoc) { if (!FullLocInfo) @@ -207,7 +207,7 @@ ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, return new ArraySubscriptExprLOC((Expr*)Base, LLoc, (Expr*)Idx, RLoc); } -ASTBuilder::ExprTy *ASTBuilder:: +Action::ExprResult ASTBuilder:: ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, tok::TokenKind OpKind, SourceLocation MemberLoc, IdentifierInfo &Member) { @@ -221,7 +221,7 @@ ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, /// ParseCallExpr - Handle a call to Fn with the specified array of arguments. /// This provides the location of the left/right parens and a list of comma /// locations. -ASTBuilder::ExprTy *ASTBuilder:: +Action::ExprResult ASTBuilder:: ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, ExprTy **Args, unsigned NumArgs, SourceLocation *CommaLocs, SourceLocation RParenLoc) { @@ -234,8 +234,8 @@ ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, // Binary Operators. 'Tok' is the token for the operator. -ASTBuilder::ExprTy *ASTBuilder::ParseBinOp(const LexerToken &Tok, ExprTy *LHS, - ExprTy *RHS) { +Action::ExprResult ASTBuilder::ParseBinOp(const LexerToken &Tok, ExprTy *LHS, + ExprTy *RHS) { BinaryOperator::Opcode Opc; switch (Tok.getKind()) { default: assert(0 && "Unknown binop!"); @@ -279,10 +279,10 @@ ASTBuilder::ExprTy *ASTBuilder::ParseBinOp(const LexerToken &Tok, ExprTy *LHS, /// ParseConditionalOp - Parse a ?: operation. Note that 'LHS' may be null /// in the case of a the GNU conditional expr extension. -ASTBuilder::ExprTy *ASTBuilder::ParseConditionalOp(SourceLocation QuestionLoc, - SourceLocation ColonLoc, - ExprTy *Cond, ExprTy *LHS, - ExprTy *RHS) { +Action::ExprResult ASTBuilder::ParseConditionalOp(SourceLocation QuestionLoc, + SourceLocation ColonLoc, + ExprTy *Cond, ExprTy *LHS, + ExprTy *RHS) { if (!FullLocInfo) return new ConditionalOperator((Expr*)Cond, (Expr*)LHS, (Expr*)RHS); else diff --git a/clang/Sema/Sema.cpp b/clang/Sema/Sema.cpp index 1ba92e1ba173..7711d183281f 100644 --- a/clang/Sema/Sema.cpp +++ b/clang/Sema/Sema.cpp @@ -42,39 +42,39 @@ public: // Expression Parsing Callbacks. // Primary Expressions. - virtual ExprTy *ParseSimplePrimaryExpr(const LexerToken &Tok); - virtual ExprTy *ParseIntegerConstant(const LexerToken &Tok); - virtual ExprTy *ParseFloatingConstant(const LexerToken &Tok); - virtual ExprTy *ParseParenExpr(SourceLocation L, SourceLocation R, - ExprTy *Val); + virtual ExprResult ParseSimplePrimaryExpr(const LexerToken &Tok); + virtual ExprResult ParseIntegerConstant(const LexerToken &Tok); + virtual ExprResult ParseFloatingConstant(const LexerToken &Tok); + virtual ExprResult ParseParenExpr(SourceLocation L, SourceLocation R, + ExprTy *Val); // Binary/Unary Operators. 'Tok' is the token for the operator. - virtual ExprTy *ParseUnaryOp(const LexerToken &Tok, ExprTy *Input); - virtual ExprTy *ParsePostfixUnaryOp(const LexerToken &Tok, ExprTy *Input); + virtual ExprResult ParseUnaryOp(const LexerToken &Tok, ExprTy *Input); + virtual ExprResult ParsePostfixUnaryOp(const LexerToken &Tok, ExprTy *Input); - virtual ExprTy *ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, - ExprTy *Idx, SourceLocation RLoc); - virtual ExprTy *ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, - tok::TokenKind OpKind, - SourceLocation MemberLoc, - IdentifierInfo &Member); + virtual ExprResult ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, + ExprTy *Idx, SourceLocation RLoc); + virtual ExprResult ParseMemberReferenceExpr(ExprTy *Base,SourceLocation OpLoc, + tok::TokenKind OpKind, + SourceLocation MemberLoc, + IdentifierInfo &Member); /// ParseCallExpr - Handle a call to Fn with the specified array of arguments. /// This provides the location of the left/right parens and a list of comma /// locations. - virtual ExprTy *ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, - ExprTy **Args, unsigned NumArgs, - SourceLocation *CommaLocs, - SourceLocation RParenLoc); + virtual ExprResult ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, + ExprTy **Args, unsigned NumArgs, + SourceLocation *CommaLocs, + SourceLocation RParenLoc); - virtual ExprTy *ParseBinOp(const LexerToken &Tok, ExprTy *LHS, ExprTy *RHS); + virtual ExprResult ParseBinOp(const LexerToken &Tok, ExprTy *LHS,ExprTy *RHS); /// ParseConditionalOp - Parse a ?: operation. Note that 'LHS' may be null /// in the case of a the GNU conditional expr extension. - virtual ExprTy *ParseConditionalOp(SourceLocation QuestionLoc, - SourceLocation ColonLoc, - ExprTy *Cond, ExprTy *LHS, ExprTy *RHS); + virtual ExprResult ParseConditionalOp(SourceLocation QuestionLoc, + SourceLocation ColonLoc, + ExprTy *Cond, ExprTy *LHS, ExprTy *RHS); }; } // end anonymous namespace @@ -123,7 +123,7 @@ void ASTBuilder::PopScope(SourceLocation Loc, Scope *S) { // Expression Parsing Callbacks. //===--------------------------------------------------------------------===// -ASTBuilder::ExprTy *ASTBuilder::ParseSimplePrimaryExpr(const LexerToken &Tok) { +Action::ExprResult ASTBuilder::ParseSimplePrimaryExpr(const LexerToken &Tok) { switch (Tok.getKind()) { default: assert(0 && "Unknown simple primary expr!"); @@ -142,16 +142,16 @@ ASTBuilder::ExprTy *ASTBuilder::ParseSimplePrimaryExpr(const LexerToken &Tok) { } } -ASTBuilder::ExprTy *ASTBuilder::ParseIntegerConstant(const LexerToken &Tok) { +Action::ExprResult ASTBuilder::ParseIntegerConstant(const LexerToken &Tok) { return new IntegerConstant(); } -ASTBuilder::ExprTy *ASTBuilder::ParseFloatingConstant(const LexerToken &Tok) { +Action::ExprResult ASTBuilder::ParseFloatingConstant(const LexerToken &Tok) { return new FloatingConstant(); } -ASTBuilder::ExprTy *ASTBuilder::ParseParenExpr(SourceLocation L, - SourceLocation R, - ExprTy *Val) { +Action::ExprResult ASTBuilder::ParseParenExpr(SourceLocation L, + SourceLocation R, + ExprTy *Val) { // FIXME: This is obviously just for testing. ((Expr*)Val)->dump(); if (!FullLocInfo) return Val; @@ -160,8 +160,8 @@ ASTBuilder::ExprTy *ASTBuilder::ParseParenExpr(SourceLocation L, } // Unary Operators. 'Tok' is the token for the operator. -ASTBuilder::ExprTy *ASTBuilder::ParseUnaryOp(const LexerToken &Tok, - ExprTy *Input) { +Action::ExprResult ASTBuilder::ParseUnaryOp(const LexerToken &Tok, + ExprTy *Input) { UnaryOperator::Opcode Opc; switch (Tok.getKind()) { default: assert(0 && "Unknown unary op!"); @@ -183,8 +183,8 @@ ASTBuilder::ExprTy *ASTBuilder::ParseUnaryOp(const LexerToken &Tok, return new UnaryOperatorLOC(Tok.getLocation(), (Expr*)Input, Opc); } -ASTBuilder::ExprTy *ASTBuilder::ParsePostfixUnaryOp(const LexerToken &Tok, - ExprTy *Input) { +Action::ExprResult ASTBuilder::ParsePostfixUnaryOp(const LexerToken &Tok, + ExprTy *Input) { UnaryOperator::Opcode Opc; switch (Tok.getKind()) { default: assert(0 && "Unknown unary op!"); @@ -198,7 +198,7 @@ ASTBuilder::ExprTy *ASTBuilder::ParsePostfixUnaryOp(const LexerToken &Tok, return new UnaryOperatorLOC(Tok.getLocation(), (Expr*)Input, Opc); } -ASTBuilder::ExprTy *ASTBuilder:: +Action::ExprResult ASTBuilder:: ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, ExprTy *Idx, SourceLocation RLoc) { if (!FullLocInfo) @@ -207,7 +207,7 @@ ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, return new ArraySubscriptExprLOC((Expr*)Base, LLoc, (Expr*)Idx, RLoc); } -ASTBuilder::ExprTy *ASTBuilder:: +Action::ExprResult ASTBuilder:: ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, tok::TokenKind OpKind, SourceLocation MemberLoc, IdentifierInfo &Member) { @@ -221,7 +221,7 @@ ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, /// ParseCallExpr - Handle a call to Fn with the specified array of arguments. /// This provides the location of the left/right parens and a list of comma /// locations. -ASTBuilder::ExprTy *ASTBuilder:: +Action::ExprResult ASTBuilder:: ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, ExprTy **Args, unsigned NumArgs, SourceLocation *CommaLocs, SourceLocation RParenLoc) { @@ -234,8 +234,8 @@ ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, // Binary Operators. 'Tok' is the token for the operator. -ASTBuilder::ExprTy *ASTBuilder::ParseBinOp(const LexerToken &Tok, ExprTy *LHS, - ExprTy *RHS) { +Action::ExprResult ASTBuilder::ParseBinOp(const LexerToken &Tok, ExprTy *LHS, + ExprTy *RHS) { BinaryOperator::Opcode Opc; switch (Tok.getKind()) { default: assert(0 && "Unknown binop!"); @@ -279,10 +279,10 @@ ASTBuilder::ExprTy *ASTBuilder::ParseBinOp(const LexerToken &Tok, ExprTy *LHS, /// ParseConditionalOp - Parse a ?: operation. Note that 'LHS' may be null /// in the case of a the GNU conditional expr extension. -ASTBuilder::ExprTy *ASTBuilder::ParseConditionalOp(SourceLocation QuestionLoc, - SourceLocation ColonLoc, - ExprTy *Cond, ExprTy *LHS, - ExprTy *RHS) { +Action::ExprResult ASTBuilder::ParseConditionalOp(SourceLocation QuestionLoc, + SourceLocation ColonLoc, + ExprTy *Cond, ExprTy *LHS, + ExprTy *RHS) { if (!FullLocInfo) return new ConditionalOperator((Expr*)Cond, (Expr*)LHS, (Expr*)RHS); else diff --git a/clang/include/clang/Parse/Action.h b/clang/include/clang/Parse/Action.h index d6a7990ddfc3..d459c5642d16 100644 --- a/clang/include/clang/Parse/Action.h +++ b/clang/include/clang/Parse/Action.h @@ -88,30 +88,30 @@ public: //===--------------------------------------------------------------------===// // Primary Expressions. - virtual ExprTy *ParseSimplePrimaryExpr(const LexerToken &Tok) { return 0; } - virtual ExprTy *ParseIntegerConstant(const LexerToken &Tok) { return 0; } - virtual ExprTy *ParseFloatingConstant(const LexerToken &Tok) { return 0; } + virtual ExprResult ParseSimplePrimaryExpr(const LexerToken &Tok) { return 0; } + virtual ExprResult ParseIntegerConstant(const LexerToken &Tok) { return 0; } + virtual ExprResult ParseFloatingConstant(const LexerToken &Tok) { return 0; } - virtual ExprTy *ParseParenExpr(SourceLocation L, SourceLocation R, - ExprTy *Val) { - return Val; + virtual ExprResult ParseParenExpr(SourceLocation L, SourceLocation R, + ExprTy *Val) { + return Val; // Default impl returns operand. } // Binary/Unary Operators. 'Tok' is the token for the operator. - virtual ExprTy *ParseUnaryOp(const LexerToken &Tok, ExprTy *Input) { + virtual ExprResult ParseUnaryOp(const LexerToken &Tok, ExprTy *Input) { return 0; } - virtual ExprTy *ParsePostfixUnaryOp(const LexerToken &Tok, ExprTy *Input) { + virtual ExprResult ParsePostfixUnaryOp(const LexerToken &Tok, ExprTy *Input) { return 0; } - virtual ExprTy *ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, - ExprTy *Idx, SourceLocation RLoc) { + virtual ExprResult ParseArraySubscriptExpr(ExprTy *Base, SourceLocation LLoc, + ExprTy *Idx, SourceLocation RLoc) { return 0; } - virtual ExprTy *ParseMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc, - tok::TokenKind OpKind, - SourceLocation MemberLoc, - IdentifierInfo &Member) { + virtual ExprResult ParseMemberReferenceExpr(ExprTy *Base,SourceLocation OpLoc, + tok::TokenKind OpKind, + SourceLocation MemberLoc, + IdentifierInfo &Member) { return 0; } @@ -119,22 +119,23 @@ public: /// This provides the location of the left/right parens and a list of comma /// locations. There are guaranteed to be one fewer commas than arguments, /// unless there are zero arguments. - virtual ExprTy *ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, - ExprTy **Args, unsigned NumArgs, - SourceLocation *CommaLocs, - SourceLocation RParenLoc) { + virtual ExprResult ParseCallExpr(ExprTy *Fn, SourceLocation LParenLoc, + ExprTy **Args, unsigned NumArgs, + SourceLocation *CommaLocs, + SourceLocation RParenLoc) { return 0; } - virtual ExprTy *ParseBinOp(const LexerToken &Tok, ExprTy *LHS, ExprTy *RHS) { + virtual ExprResult ParseBinOp(const LexerToken &Tok, + ExprTy *LHS, ExprTy *RHS) { return 0; } /// ParseConditionalOp - Parse a ?: operation. Note that 'LHS' may be null /// in the case of a the GNU conditional expr extension. - virtual ExprTy *ParseConditionalOp(SourceLocation QuestionLoc, - SourceLocation ColonLoc, - ExprTy *Cond, ExprTy *LHS, ExprTy *RHS) { + virtual ExprResult ParseConditionalOp(SourceLocation QuestionLoc, + SourceLocation ColonLoc, + ExprTy *Cond, ExprTy *LHS, ExprTy *RHS){ return 0; } };