From: Anders Carlsson Date: Thu, 3 Sep 2009 00:59:21 +0000 (+0000) Subject: Add CastExpr::getCastKindName and use it in the StmtDumper. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f8ec55a104e55961f8666f773dce99bbc628298f;p=clang Add CastExpr::getCastKindName and use it in the StmtDumper. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@80862 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/AST/Expr.h b/include/clang/AST/Expr.h index 750b72cbcf..0d333e2ee4 100644 --- a/include/clang/AST/Expr.h +++ b/include/clang/AST/Expr.h @@ -1395,7 +1395,8 @@ protected: public: CastKind getCastKind() const { return Kind; } void setCastKind(CastKind K) { Kind = K; } - + const char *getCastKindName() const; + Expr *getSubExpr() { return cast(Op); } const Expr *getSubExpr() const { return cast(Op); } void setSubExpr(Expr *E) { Op = E; } diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp index a69448e7bc..daa98aeeab 100644 --- a/lib/AST/Expr.cpp +++ b/lib/AST/Expr.cpp @@ -319,6 +319,38 @@ MemberExpr *MemberExpr::Create(ASTContext &C, Expr *base, bool isarrow, ty); } +const char *CastExpr::getCastKindName() const { + switch (getCastKind()) { + case CastExpr::CK_Unknown: + return "Unknown"; + case CastExpr::CK_BitCast: + return "BitCast"; + case CastExpr::CK_NoOp: + return "NoOp"; + case CastExpr::CK_DerivedToBase: + return "DerivedToBase"; + case CastExpr::CK_Dynamic: + return "Dynamic"; + case CastExpr::CK_ToUnion: + return "ToUnion"; + case CastExpr::CK_ArrayToPointerDecay: + return "ArrayToPointerDecay"; + case CastExpr::CK_FunctionToPointerDecay: + return "FunctionToPointerDecay"; + case CastExpr::CK_NullToMemberPointer: + return "NullToMemberPointer"; + case CastExpr::CK_BaseToDerivedMemberPointer: + return "BaseToDerivedMemberPointer"; + case CastExpr::CK_UserDefinedConversion: + return "UserDefinedConversion"; + case CastExpr::CK_ConstructorConversion: + return "ConstructorConversion"; + } + + assert(0 && "Unhandled cast kind!"); + return 0; +} + /// getOpcodeStr - Turn an Opcode enum value into the punctuation char it /// corresponds to, e.g. "<<=". const char *BinaryOperator::getOpcodeStr(Opcode Op) { diff --git a/lib/AST/StmtDumper.cpp b/lib/AST/StmtDumper.cpp index 7d8d64cb63..5f320095e7 100644 --- a/lib/AST/StmtDumper.cpp +++ b/lib/AST/StmtDumper.cpp @@ -301,45 +301,7 @@ void StmtDumper::VisitExpr(Expr *Node) { void StmtDumper::VisitCastExpr(CastExpr *Node) { DumpExpr(Node); - fprintf(F, " "); - switch (Node->getCastKind()) { - case CastExpr::CK_Unknown: - fprintf(F, ""); - break; - case CastExpr::CK_BitCast: - fprintf(F, ""); - break; - case CastExpr::CK_NoOp: - fprintf(F, ""); - break; - case CastExpr::CK_DerivedToBase: - fprintf(F, ""); - break; - case CastExpr::CK_Dynamic: - fprintf(F, ""); - break; - case CastExpr::CK_ToUnion: - fprintf(F, ""); - break; - case CastExpr::CK_ArrayToPointerDecay: - fprintf(F, ""); - break; - case CastExpr::CK_FunctionToPointerDecay: - fprintf(F, ""); - break; - case CastExpr::CK_NullToMemberPointer: - fprintf(F, ""); - break; - case CastExpr::CK_BaseToDerivedMemberPointer: - fprintf(F, ""); - break; - case CastExpr::CK_UserDefinedConversion: - fprintf(F, ""); - break; - case CastExpr::CK_ConstructorConversion: - fprintf(F, ""); - break; - } + fprintf(F, " <%s>", Node->getCastKindName()); } void StmtDumper::VisitDeclRefExpr(DeclRefExpr *Node) { @@ -480,8 +442,9 @@ void StmtDumper::VisitTypesCompatibleExpr(TypesCompatibleExpr *Node) { void StmtDumper::VisitCXXNamedCastExpr(CXXNamedCastExpr *Node) { DumpExpr(Node); - fprintf(F, " %s<%s>", Node->getCastName(), - Node->getTypeAsWritten().getAsString().c_str()); + fprintf(F, " %s<%s> <%s>", Node->getCastName(), + Node->getTypeAsWritten().getAsString().c_str(), + Node->getCastKindName()); } void StmtDumper::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *Node) {