diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-09-03 00:59:21 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-09-03 00:59:21 +0000 |
| commit | 496335ea1a7a231c7a5b1d2801d94b23f0a080b0 (patch) | |
| tree | 499b47bc8f2ab4966246959716b194d986e0c326 /clang/lib | |
| parent | 517ea46e2eb5990d56c4737c05fc8cdad3f65fa5 (diff) | |
| download | bcm5719-llvm-496335ea1a7a231c7a5b1d2801d94b23f0a080b0.tar.gz bcm5719-llvm-496335ea1a7a231c7a5b1d2801d94b23f0a080b0.zip | |
Add CastExpr::getCastKindName and use it in the StmtDumper.
llvm-svn: 80862
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/AST/Expr.cpp | 32 | ||||
| -rw-r--r-- | clang/lib/AST/StmtDumper.cpp | 45 |
2 files changed, 36 insertions, 41 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp index a69448e7bc8..daa98aeeabc 100644 --- a/clang/lib/AST/Expr.cpp +++ b/clang/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/clang/lib/AST/StmtDumper.cpp b/clang/lib/AST/StmtDumper.cpp index 7d8d64cb63a..5f320095e7f 100644 --- a/clang/lib/AST/StmtDumper.cpp +++ b/clang/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, "<Unknown>"); - break; - case CastExpr::CK_BitCast: - fprintf(F, "<BitCast>"); - break; - case CastExpr::CK_NoOp: - fprintf(F, "<NoOp>"); - break; - case CastExpr::CK_DerivedToBase: - fprintf(F, "<DerivedToBase>"); - break; - case CastExpr::CK_Dynamic: - fprintf(F, "<Dynamic>"); - break; - case CastExpr::CK_ToUnion: - fprintf(F, "<ToUnion>"); - break; - case CastExpr::CK_ArrayToPointerDecay: - fprintf(F, "<ArrayToPointerDecay>"); - break; - case CastExpr::CK_FunctionToPointerDecay: - fprintf(F, "<FunctionToPointerDecay>"); - break; - case CastExpr::CK_NullToMemberPointer: - fprintf(F, "<NullToMemberPointer>"); - break; - case CastExpr::CK_BaseToDerivedMemberPointer: - fprintf(F, "<BaseToDerivedMemberPointer>"); - break; - case CastExpr::CK_UserDefinedConversion: - fprintf(F, "<UserDefinedConversion>"); - break; - case CastExpr::CK_ConstructorConversion: - fprintf(F, "<ConstructorConversion>"); - 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) { |

