aboutsummaryrefslogtreecommitdiff
path: root/lib/AST
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-01-11 23:09:57 +0000
committerDouglas Gregor <dgregor@apple.com>2011-01-11 23:09:57 +0000
commit203e6a322ae29d577acafcb1572a57ec16e1e730 (patch)
treeeb678f079634c2ec3d50e4a18eedad9331d23512 /lib/AST
parent82a0f4e93c055fb12f5ad7c3d146d50eb201308f (diff)
Add TemplateArgument::CreatePackCopy() to create a new parameter pack
in ASTContext-allocated memory, copying the provided template arguments. Use this new routine where we can. No functionality change. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@123289 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST')
-rw-r--r--lib/AST/DeclTemplate.cpp7
-rw-r--r--lib/AST/TemplateBase.cpp12
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: