diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-05 15:48:55 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-05 15:48:55 +0000 |
commit | f550077ef5abe24aa34ccba1d3ad5bbcc9387be7 (patch) | |
tree | 436efb71d09100f5e5664fd7fd444cb44db1e3f5 /clang/lib/Sema/SemaTemplateVariadic.cpp | |
parent | c7d65b42fce5969949a6f099fd4fea383cbf69d9 (diff) | |
download | bcm5719-llvm-f550077ef5abe24aa34ccba1d3ad5bbcc9387be7.tar.gz bcm5719-llvm-f550077ef5abe24aa34ccba1d3ad5bbcc9387be7.zip |
Implement support for template template parameter packs, e.g.,
template<template<class> class ...Metafunctions>
struct apply_to_each;
llvm-svn: 122874
Diffstat (limited to 'clang/lib/Sema/SemaTemplateVariadic.cpp')
-rw-r--r-- | clang/lib/Sema/SemaTemplateVariadic.cpp | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaTemplateVariadic.cpp b/clang/lib/Sema/SemaTemplateVariadic.cpp index 4e01ec2407d..acb73144d92 100644 --- a/clang/lib/Sema/SemaTemplateVariadic.cpp +++ b/clang/lib/Sema/SemaTemplateVariadic.cpp @@ -78,7 +78,16 @@ namespace { return true; } - // FIXME: Record occurrences of template template parameter packs. + /// \brief Record occurrences of template template parameter packs. + bool TraverseTemplateName(TemplateName Template) { + if (TemplateTemplateParmDecl *TTP + = dyn_cast_or_null<TemplateTemplateParmDecl>( + Template.getAsTemplateDecl())) + if (TTP->isParameterPack()) + Unexpanded.push_back(std::make_pair(TTP, SourceLocation())); + + return inherited::TraverseTemplateName(Template); + } //------------------------------------------------------------------------ // Pruning the search for unexpanded parameter packs. @@ -556,7 +565,6 @@ ExprResult Sema::ActOnSizeofParameterPackExpr(Scope *S, SourceLocation RParenLoc) { // C++0x [expr.sizeof]p5: // The identifier in a sizeof... expression shall name a parameter pack. - LookupResult R(*this, &Name, NameLoc, LookupOrdinaryName); LookupName(R, S); |