diff options
| author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2008-12-22 21:35:02 +0000 |
|---|---|---|
| committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2008-12-22 21:35:02 +0000 |
| commit | 9b244a8797ebcc5d315246d90a74fed432a6972b (patch) | |
| tree | b9aea8b9ccb110f2d296a732afd983230956a481 /clang/lib/AST/StmtPrinter.cpp | |
| parent | 014caa431ce555ea1420f8d173865c9a204d694a (diff) | |
| download | bcm5719-llvm-9b244a8797ebcc5d315246d90a74fed432a6972b.tar.gz bcm5719-llvm-9b244a8797ebcc5d315246d90a74fed432a6972b.zip | |
Full AST support and better Sema support for C++ try-catch.
llvm-svn: 61346
Diffstat (limited to 'clang/lib/AST/StmtPrinter.cpp')
| -rw-r--r-- | clang/lib/AST/StmtPrinter.cpp | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/clang/lib/AST/StmtPrinter.cpp b/clang/lib/AST/StmtPrinter.cpp index 61cd89f70fa..521478953f2 100644 --- a/clang/lib/AST/StmtPrinter.cpp +++ b/clang/lib/AST/StmtPrinter.cpp @@ -52,6 +52,7 @@ namespace { void PrintRawDecl(Decl *D); void PrintRawDeclStmt(DeclStmt *S); void PrintRawIfStmt(IfStmt *If); + void PrintRawCXXCatchStmt(CXXCatchStmt *Catch); void PrintExpr(Expr *E) { if (E) @@ -474,14 +475,29 @@ void StmtPrinter::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *Node) { OS << "\n"; } -void StmtPrinter::VisitCXXCatchStmt(CXXCatchStmt *Node) { - Indent() << "catch ("; +void StmtPrinter::PrintRawCXXCatchStmt(CXXCatchStmt *Node) { + OS << "catch ("; if (Decl *ExDecl = Node->getExceptionDecl()) PrintRawDecl(ExDecl); else OS << "..."; OS << ") "; PrintRawCompoundStmt(cast<CompoundStmt>(Node->getHandlerBlock())); +} + +void StmtPrinter::VisitCXXCatchStmt(CXXCatchStmt *Node) { + Indent(); + PrintRawCXXCatchStmt(Node); + OS << "\n"; +} + +void StmtPrinter::VisitCXXTryStmt(CXXTryStmt *Node) { + Indent() << "try "; + PrintRawCompoundStmt(Node->getTryBlock()); + for(unsigned i = 0, e = Node->getNumHandlers(); i < e; ++i) { + OS << " "; + PrintRawCXXCatchStmt(Node->getHandler(i)); + } OS << "\n"; } |

