forked from OSchip/llvm-project
Remove abstract expression kinds from the StmtClass enum. Update a few users
appropriately. Call out a few missing cases in the expression mangler. llvm-svn: 95176
This commit is contained in:
parent
dee74e2805
commit
2adddcae7e
|
@ -1748,7 +1748,7 @@ public:
|
||||||
|
|
||||||
static bool classof(const Stmt *T) {
|
static bool classof(const Stmt *T) {
|
||||||
StmtClass SC = T->getStmtClass();
|
StmtClass SC = T->getStmtClass();
|
||||||
if (SC >= ExplicitCastExprClass && SC <= CStyleCastExprClass)
|
if (SC >= CStyleCastExprClass && SC <= CStyleCastExprClass)
|
||||||
return true;
|
return true;
|
||||||
if (SC >= CXXNamedCastExprClass && SC <= CXXFunctionalCastExprClass)
|
if (SC >= CXXNamedCastExprClass && SC <= CXXFunctionalCastExprClass)
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -102,6 +102,7 @@ public:
|
||||||
#define LAST_STMT(CLASS) lastStmtConstant = CLASS##Class,
|
#define LAST_STMT(CLASS) lastStmtConstant = CLASS##Class,
|
||||||
#define FIRST_EXPR(CLASS) firstExprConstant = CLASS##Class,
|
#define FIRST_EXPR(CLASS) firstExprConstant = CLASS##Class,
|
||||||
#define LAST_EXPR(CLASS) lastExprConstant = CLASS##Class
|
#define LAST_EXPR(CLASS) lastExprConstant = CLASS##Class
|
||||||
|
#define ABSTRACT_EXPR(CLASS, PARENT)
|
||||||
#include "clang/AST/StmtNodes.def"
|
#include "clang/AST/StmtNodes.def"
|
||||||
};
|
};
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -68,8 +68,7 @@ STMT(CXXTryStmt , Stmt)
|
||||||
LAST_STMT(CXXTryStmt)
|
LAST_STMT(CXXTryStmt)
|
||||||
|
|
||||||
// Expressions.
|
// Expressions.
|
||||||
ABSTRACT_EXPR(Expr , Stmt)
|
ABSTRACT_EXPR(Expr , Stmt)
|
||||||
FIRST_EXPR(Expr)
|
|
||||||
EXPR(PredefinedExpr , Expr)
|
EXPR(PredefinedExpr , Expr)
|
||||||
EXPR(DeclRefExpr , Expr)
|
EXPR(DeclRefExpr , Expr)
|
||||||
EXPR(IntegerLiteral , Expr)
|
EXPR(IntegerLiteral , Expr)
|
||||||
|
@ -83,12 +82,12 @@ EXPR(SizeOfAlignOfExpr , Expr)
|
||||||
EXPR(ArraySubscriptExpr , Expr)
|
EXPR(ArraySubscriptExpr , Expr)
|
||||||
EXPR(CallExpr , Expr)
|
EXPR(CallExpr , Expr)
|
||||||
EXPR(MemberExpr , Expr)
|
EXPR(MemberExpr , Expr)
|
||||||
EXPR(CastExpr , Expr)
|
ABSTRACT_EXPR(CastExpr , Expr)
|
||||||
EXPR(BinaryOperator , Expr)
|
EXPR(BinaryOperator , Expr)
|
||||||
EXPR(CompoundAssignOperator, BinaryOperator)
|
EXPR(CompoundAssignOperator, BinaryOperator)
|
||||||
EXPR(ConditionalOperator , Expr)
|
EXPR(ConditionalOperator , Expr)
|
||||||
EXPR(ImplicitCastExpr , CastExpr)
|
EXPR(ImplicitCastExpr , CastExpr)
|
||||||
EXPR(ExplicitCastExpr , CastExpr)
|
ABSTRACT_EXPR(ExplicitCastExpr, CastExpr)
|
||||||
EXPR(CStyleCastExpr , ExplicitCastExpr)
|
EXPR(CStyleCastExpr , ExplicitCastExpr)
|
||||||
EXPR(CompoundLiteralExpr , Expr)
|
EXPR(CompoundLiteralExpr , Expr)
|
||||||
EXPR(ExtVectorElementExpr , Expr)
|
EXPR(ExtVectorElementExpr , Expr)
|
||||||
|
@ -153,6 +152,7 @@ EXPR(ShuffleVectorExpr , Expr)
|
||||||
EXPR(BlockExpr , Expr)
|
EXPR(BlockExpr , Expr)
|
||||||
EXPR(BlockDeclRefExpr , Expr)
|
EXPR(BlockDeclRefExpr , Expr)
|
||||||
|
|
||||||
|
FIRST_EXPR(PredefinedExpr)
|
||||||
LAST_EXPR(BlockDeclRefExpr)
|
LAST_EXPR(BlockDeclRefExpr)
|
||||||
|
|
||||||
#undef ABSTRACT_EXPR
|
#undef ABSTRACT_EXPR
|
||||||
|
|
|
@ -105,6 +105,7 @@ public:
|
||||||
// Top switch stmt: dispatch to VisitFooStmt for each FooStmt.
|
// Top switch stmt: dispatch to VisitFooStmt for each FooStmt.
|
||||||
switch (S->getStmtClass()) {
|
switch (S->getStmtClass()) {
|
||||||
default: assert(0 && "Unknown stmt kind!");
|
default: assert(0 && "Unknown stmt kind!");
|
||||||
|
#define ABSTRACT_EXPR(CLASS, PARENT)
|
||||||
#define STMT(CLASS, PARENT) \
|
#define STMT(CLASS, PARENT) \
|
||||||
case Stmt::CLASS ## Class: DISPATCH(CLASS, CLASS);
|
case Stmt::CLASS ## Class: DISPATCH(CLASS, CLASS);
|
||||||
#include "clang/AST/StmtNodes.def"
|
#include "clang/AST/StmtNodes.def"
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
PREVISIT(ArraySubscriptExpr, Stmt)
|
PREVISIT(ArraySubscriptExpr, Stmt)
|
||||||
PREVISIT(BinaryOperator, Stmt)
|
PREVISIT(BinaryOperator, Stmt)
|
||||||
PREVISIT(CallExpr, Stmt)
|
PREVISIT(CallExpr, Stmt)
|
||||||
PREVISIT(CastExpr, Stmt)
|
|
||||||
PREVISIT(CXXOperatorCallExpr, CallExpr)
|
PREVISIT(CXXOperatorCallExpr, CallExpr)
|
||||||
PREVISIT(DeclStmt, Stmt)
|
PREVISIT(DeclStmt, Stmt)
|
||||||
PREVISIT(ObjCMessageExpr, Stmt)
|
PREVISIT(ObjCMessageExpr, Stmt)
|
||||||
|
|
|
@ -42,7 +42,6 @@ public:
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case Stmt::ImplicitCastExprClass:
|
case Stmt::ImplicitCastExprClass:
|
||||||
case Stmt::ExplicitCastExprClass:
|
|
||||||
case Stmt::CStyleCastExprClass:
|
case Stmt::CStyleCastExprClass:
|
||||||
static_cast<ImplClass*>(this)->PreVisitCastExpr(C,
|
static_cast<ImplClass*>(this)->PreVisitCastExpr(C,
|
||||||
static_cast<const CastExpr*>(S));
|
static_cast<const CastExpr*>(S));
|
||||||
|
@ -82,16 +81,18 @@ break;
|
||||||
|
|
||||||
void PreVisitStmt(CheckerContext &C, const Stmt *S) {}
|
void PreVisitStmt(CheckerContext &C, const Stmt *S) {}
|
||||||
void PostVisitStmt(CheckerContext &C, const Stmt *S) {}
|
void PostVisitStmt(CheckerContext &C, const Stmt *S) {}
|
||||||
|
|
||||||
|
void PreVisitCastExpr(CheckerContext &C, const CastExpr *E) {
|
||||||
|
static_cast<ImplClass*>(this)->PreVisitStmt(C, E);
|
||||||
|
}
|
||||||
|
|
||||||
#define PREVISIT(NAME, FALLBACK) \
|
#define PREVISIT(NAME, FALLBACK) \
|
||||||
void PreVisit ## NAME(CheckerContext &C, const NAME* S) {\
|
void PreVisit ## NAME(CheckerContext &C, const NAME* S) {\
|
||||||
PreVisit ## FALLBACK(C, S);\
|
static_cast<ImplClass*>(this)->PreVisit ## FALLBACK(C, S);\
|
||||||
}
|
}
|
||||||
#include "clang/Checker/PathSensitive/CheckerVisitor.def"
|
|
||||||
|
|
||||||
#define POSTVISIT(NAME, FALLBACK) \
|
#define POSTVISIT(NAME, FALLBACK) \
|
||||||
void PostVisit ## NAME(CheckerContext &C, const NAME* S) {\
|
void PostVisit ## NAME(CheckerContext &C, const NAME* S) {\
|
||||||
PostVisit ## FALLBACK(C, S);\
|
static_cast<ImplClass*>(this)->PostVisit ## FALLBACK(C, S);\
|
||||||
}
|
}
|
||||||
#include "clang/Checker/PathSensitive/CheckerVisitor.def"
|
#include "clang/Checker/PathSensitive/CheckerVisitor.def"
|
||||||
};
|
};
|
||||||
|
|
|
@ -1616,7 +1616,6 @@ static ICEDiag CheckICE(const Expr* E, ASTContext &Ctx) {
|
||||||
case Expr::BlockExprClass:
|
case Expr::BlockExprClass:
|
||||||
case Expr::BlockDeclRefExprClass:
|
case Expr::BlockDeclRefExprClass:
|
||||||
case Expr::NoStmtClass:
|
case Expr::NoStmtClass:
|
||||||
case Expr::ExprClass:
|
|
||||||
return ICEDiag(2, E->getLocStart());
|
return ICEDiag(2, E->getLocStart());
|
||||||
|
|
||||||
case Expr::GNUNullExprClass:
|
case Expr::GNUNullExprClass:
|
||||||
|
@ -1812,9 +1811,7 @@ static ICEDiag CheckICE(const Expr* E, ASTContext &Ctx) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case Expr::CastExprClass:
|
|
||||||
case Expr::ImplicitCastExprClass:
|
case Expr::ImplicitCastExprClass:
|
||||||
case Expr::ExplicitCastExprClass:
|
|
||||||
case Expr::CStyleCastExprClass:
|
case Expr::CStyleCastExprClass:
|
||||||
case Expr::CXXFunctionalCastExprClass:
|
case Expr::CXXFunctionalCastExprClass:
|
||||||
case Expr::CXXNamedCastExprClass:
|
case Expr::CXXNamedCastExprClass:
|
||||||
|
|
|
@ -35,6 +35,7 @@ static StmtClassNameTable &getStmtInfoTableEntry(Stmt::StmtClass E) {
|
||||||
|
|
||||||
// Intialize the table on the first use.
|
// Intialize the table on the first use.
|
||||||
Initialized = true;
|
Initialized = true;
|
||||||
|
#define ABSTRACT_EXPR(CLASS, PARENT)
|
||||||
#define STMT(CLASS, PARENT) \
|
#define STMT(CLASS, PARENT) \
|
||||||
StmtClassInfo[(unsigned)Stmt::CLASS##Class].Name = #CLASS; \
|
StmtClassInfo[(unsigned)Stmt::CLASS##Class].Name = #CLASS; \
|
||||||
StmtClassInfo[(unsigned)Stmt::CLASS##Class].Size = sizeof(CLASS);
|
StmtClassInfo[(unsigned)Stmt::CLASS##Class].Size = sizeof(CLASS);
|
||||||
|
|
|
@ -1056,21 +1056,38 @@ void CXXNameMangler::mangleIntegerLiteral(QualType T,
|
||||||
|
|
||||||
void CXXNameMangler::mangleExpression(const Expr *E) {
|
void CXXNameMangler::mangleExpression(const Expr *E) {
|
||||||
// <expression> ::= <unary operator-name> <expression>
|
// <expression> ::= <unary operator-name> <expression>
|
||||||
// ::= <binary operator-name> <expression> <expression>
|
// ::= <binary operator-name> <expression> <expression>
|
||||||
// ::= <trinary operator-name> <expression> <expression> <expression>
|
// ::= <trinary operator-name> <expression> <expression> <expression>
|
||||||
// ::= cl <expression>* E # call
|
// ::= cl <expression>* E # call
|
||||||
// ::= cv <type> expression # conversion with one argument
|
// ::= cv <type> expression # conversion with one argument
|
||||||
// ::= cv <type> _ <expression>* E # conversion with a different number of arguments
|
// ::= cv <type> _ <expression>* E # conversion with a different number of arguments
|
||||||
// ::= st <type> # sizeof (a type)
|
// ::= st <type> # sizeof (a type)
|
||||||
// ::= at <type> # alignof (a type)
|
// ::= at <type> # alignof (a type)
|
||||||
// ::= <template-param>
|
// ::= <template-param>
|
||||||
// ::= <function-param>
|
// ::= <function-param>
|
||||||
// ::= sr <type> <unqualified-name> # dependent name
|
// ::= sr <type> <unqualified-name> # dependent name
|
||||||
// ::= sr <type> <unqualified-name> <template-args> # dependent template-id
|
// ::= sr <type> <unqualified-name> <template-args> # dependent template-id
|
||||||
// ::= sZ <template-param> # size of a parameter pack
|
// ::= sZ <template-param> # size of a parameter pack
|
||||||
// ::= <expr-primary>
|
// ::= <expr-primary>
|
||||||
switch (E->getStmtClass()) {
|
switch (E->getStmtClass()) {
|
||||||
default: assert(false && "Unhandled expression kind!");
|
default:
|
||||||
|
llvm_unreachable("unexpected statement kind");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Expr::CallExprClass:
|
||||||
|
// FIXME: implement
|
||||||
|
llvm_unreachable("mangling not implemented for calls");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Expr::CXXConstructExprClass:
|
||||||
|
// FIXME: implement
|
||||||
|
llvm_unreachable("mangling not implemented for construct exprs");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Expr::SizeOfAlignOfExprClass:
|
||||||
|
// FIXME: implement
|
||||||
|
llvm_unreachable("mangling not implemented for sizeof/alignof");
|
||||||
|
break;
|
||||||
|
|
||||||
case Expr::UnaryOperatorClass: {
|
case Expr::UnaryOperatorClass: {
|
||||||
const UnaryOperator *UO = cast<UnaryOperator>(E);
|
const UnaryOperator *UO = cast<UnaryOperator>(E);
|
||||||
|
|
|
@ -1684,6 +1684,7 @@ Sema::OwningStmtResult TreeTransform<Derived>::TransformStmt(Stmt *S) {
|
||||||
|
|
||||||
// Transform expressions by calling TransformExpr.
|
// Transform expressions by calling TransformExpr.
|
||||||
#define STMT(Node, Parent)
|
#define STMT(Node, Parent)
|
||||||
|
#define ABSTRACT_EXPR(Node, Parent)
|
||||||
#define EXPR(Node, Parent) case Stmt::Node##Class:
|
#define EXPR(Node, Parent) case Stmt::Node##Class:
|
||||||
#include "clang/AST/StmtNodes.def"
|
#include "clang/AST/StmtNodes.def"
|
||||||
{
|
{
|
||||||
|
@ -1707,6 +1708,7 @@ Sema::OwningExprResult TreeTransform<Derived>::TransformExpr(Expr *E) {
|
||||||
switch (E->getStmtClass()) {
|
switch (E->getStmtClass()) {
|
||||||
case Stmt::NoStmtClass: break;
|
case Stmt::NoStmtClass: break;
|
||||||
#define STMT(Node, Parent) case Stmt::Node##Class: break;
|
#define STMT(Node, Parent) case Stmt::Node##Class: break;
|
||||||
|
#define ABSTRACT_EXPR(Node, Parent)
|
||||||
#define EXPR(Node, Parent) \
|
#define EXPR(Node, Parent) \
|
||||||
case Stmt::Node##Class: return getDerived().Transform##Node(cast<Node>(E));
|
case Stmt::Node##Class: return getDerived().Transform##Node(cast<Node>(E));
|
||||||
#include "clang/AST/StmtNodes.def"
|
#include "clang/AST/StmtNodes.def"
|
||||||
|
@ -3827,13 +3829,6 @@ TreeTransform<Derived>::TransformMemberExpr(MemberExpr *E) {
|
||||||
FirstQualifierInScope);
|
FirstQualifierInScope);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename Derived>
|
|
||||||
Sema::OwningExprResult
|
|
||||||
TreeTransform<Derived>::TransformCastExpr(CastExpr *E) {
|
|
||||||
assert(false && "Cannot transform abstract class");
|
|
||||||
return SemaRef.Owned(E->Retain());
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename Derived>
|
template<typename Derived>
|
||||||
Sema::OwningExprResult
|
Sema::OwningExprResult
|
||||||
TreeTransform<Derived>::TransformBinaryOperator(BinaryOperator *E) {
|
TreeTransform<Derived>::TransformBinaryOperator(BinaryOperator *E) {
|
||||||
|
@ -3897,13 +3892,6 @@ TreeTransform<Derived>::TransformImplicitCastExpr(ImplicitCastExpr *E) {
|
||||||
return getDerived().TransformExpr(E->getSubExprAsWritten());
|
return getDerived().TransformExpr(E->getSubExprAsWritten());
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename Derived>
|
|
||||||
Sema::OwningExprResult
|
|
||||||
TreeTransform<Derived>::TransformExplicitCastExpr(ExplicitCastExpr *E) {
|
|
||||||
assert(false && "Cannot transform abstract class");
|
|
||||||
return SemaRef.Owned(E->Retain());
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename Derived>
|
template<typename Derived>
|
||||||
Sema::OwningExprResult
|
Sema::OwningExprResult
|
||||||
TreeTransform<Derived>::TransformCStyleCastExpr(CStyleCastExpr *E) {
|
TreeTransform<Derived>::TransformCStyleCastExpr(CStyleCastExpr *E) {
|
||||||
|
|
|
@ -115,7 +115,6 @@ CXCursor cxcursor::MakeCXCursor(Stmt *S, Decl *Parent, ASTUnit *TU) {
|
||||||
K = CXCursor_UnexposedStmt;
|
K = CXCursor_UnexposedStmt;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Stmt::ExprClass:
|
|
||||||
case Stmt::PredefinedExprClass:
|
case Stmt::PredefinedExprClass:
|
||||||
case Stmt::IntegerLiteralClass:
|
case Stmt::IntegerLiteralClass:
|
||||||
case Stmt::FloatingLiteralClass:
|
case Stmt::FloatingLiteralClass:
|
||||||
|
@ -126,12 +125,10 @@ CXCursor cxcursor::MakeCXCursor(Stmt *S, Decl *Parent, ASTUnit *TU) {
|
||||||
case Stmt::UnaryOperatorClass:
|
case Stmt::UnaryOperatorClass:
|
||||||
case Stmt::SizeOfAlignOfExprClass:
|
case Stmt::SizeOfAlignOfExprClass:
|
||||||
case Stmt::ArraySubscriptExprClass:
|
case Stmt::ArraySubscriptExprClass:
|
||||||
case Stmt::CastExprClass:
|
|
||||||
case Stmt::BinaryOperatorClass:
|
case Stmt::BinaryOperatorClass:
|
||||||
case Stmt::CompoundAssignOperatorClass:
|
case Stmt::CompoundAssignOperatorClass:
|
||||||
case Stmt::ConditionalOperatorClass:
|
case Stmt::ConditionalOperatorClass:
|
||||||
case Stmt::ImplicitCastExprClass:
|
case Stmt::ImplicitCastExprClass:
|
||||||
case Stmt::ExplicitCastExprClass:
|
|
||||||
case Stmt::CStyleCastExprClass:
|
case Stmt::CStyleCastExprClass:
|
||||||
case Stmt::CompoundLiteralExprClass:
|
case Stmt::CompoundLiteralExprClass:
|
||||||
case Stmt::ExtVectorElementExprClass:
|
case Stmt::ExtVectorElementExprClass:
|
||||||
|
|
Loading…
Reference in New Issue