diff options
Diffstat (limited to 'lib/AST')
-rw-r--r-- | lib/AST/DeclTemplate.cpp | 7 | ||||
-rw-r--r-- | lib/AST/TemplateBase.cpp | 12 |
2 files changed, 14 insertions, 5 deletions
diff --git a/lib/AST/DeclTemplate.cpp b/lib/AST/DeclTemplate.cpp index b7a586cb17..6e08854231 100644 --- a/lib/AST/DeclTemplate.cpp +++ b/lib/AST/DeclTemplate.cpp @@ -338,11 +338,8 @@ ClassTemplateDecl::getInjectedClassNameSpecialization() { Arg = TemplateArgument(TemplateName(TTP), TTP->isParameterPack()); } - if ((*Param)->isTemplateParameterPack()) { - TemplateArgument *Pack = new (Context) TemplateArgument [1]; - *Pack = Arg; - Arg = TemplateArgument(Pack, 1); - } + if ((*Param)->isTemplateParameterPack()) + Arg = TemplateArgument::CreatePackCopy(Context, &Arg, 1); TemplateArgs.push_back(Arg); } diff --git a/lib/AST/TemplateBase.cpp b/lib/AST/TemplateBase.cpp index 68e23323ce..6d6fee6625 100644 --- a/lib/AST/TemplateBase.cpp +++ b/lib/AST/TemplateBase.cpp @@ -21,6 +21,7 @@ #include "clang/AST/TypeLoc.h" #include "clang/Basic/Diagnostic.h" #include "llvm/ADT/FoldingSet.h" +#include <algorithm> using namespace clang; @@ -28,6 +29,17 @@ using namespace clang; // TemplateArgument Implementation //===----------------------------------------------------------------------===// +TemplateArgument TemplateArgument::CreatePackCopy(ASTContext &Context, + const TemplateArgument *Args, + unsigned NumArgs) { + if (NumArgs == 0) + return TemplateArgument(0, 0); + + TemplateArgument *Storage = new (Context) TemplateArgument [NumArgs]; + std::copy(Args, Args + NumArgs, Storage); + return TemplateArgument(Storage, NumArgs); +} + bool TemplateArgument::isDependent() const { switch (getKind()) { case Null: |