diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-09 10:10:02 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-09 10:10:02 +0000 |
commit | 29e9595bd783b032c96f60a8602bb2b7d136e735 (patch) | |
tree | 8052b246606c99738c5efb57b8e2ba5d4caf16de /clang/lib/AST/StmtPrinter.cpp | |
parent | f32638d77c73bdd31c7eeaff6acdc68a48fabe4e (diff) | |
download | bcm5719-llvm-29e9595bd783b032c96f60a8602bb2b7d136e735.tar.gz bcm5719-llvm-29e9595bd783b032c96f60a8602bb2b7d136e735.zip |
Fix statement printing for raw and template user-defined literals.
llvm-svn: 152401
Diffstat (limited to 'clang/lib/AST/StmtPrinter.cpp')
-rw-r--r-- | clang/lib/AST/StmtPrinter.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/clang/lib/AST/StmtPrinter.cpp b/clang/lib/AST/StmtPrinter.cpp index d2233e094bb..d5e53a69d44 100644 --- a/clang/lib/AST/StmtPrinter.cpp +++ b/clang/lib/AST/StmtPrinter.cpp @@ -1225,14 +1225,17 @@ void StmtPrinter::VisitCXXUuidofExpr(CXXUuidofExpr *Node) { void StmtPrinter::VisitUserDefinedLiteral(UserDefinedLiteral *Node) { switch (Node->getLiteralOperatorKind()) { case UserDefinedLiteral::LOK_Raw: - OS << cast<StringLiteral>(Node->getArg(0))->getString(); + OS << cast<StringLiteral>(Node->getArg(0)->IgnoreImpCasts())->getString(); break; case UserDefinedLiteral::LOK_Template: { - DeclRefExpr *DRE = cast<DeclRefExpr>(Node->getCallee()); - assert(DRE->hasExplicitTemplateArgs()); - const TemplateArgumentLoc *Args = DRE->getTemplateArgs(); - for (unsigned i = 0, e = DRE->getNumTemplateArgs(); i != e; ++i) { - char C = (char)Args[i].getArgument().getAsIntegral()->getZExtValue(); + DeclRefExpr *DRE = cast<DeclRefExpr>(Node->getCallee()->IgnoreImpCasts()); + const TemplateArgumentList *Args = + cast<FunctionDecl>(DRE->getDecl())->getTemplateSpecializationArgs(); + assert(Args); + const TemplateArgument &Pack = Args->get(0); + for (TemplateArgument::pack_iterator I = Pack.pack_begin(), + E = Pack.pack_end(); I != E; ++I) { + char C = (char)I->getAsIntegral()->getZExtValue(); OS << C; } break; |