diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-11 23:09:57 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-11 23:09:57 +0000 |
commit | 203e6a322ae29d577acafcb1572a57ec16e1e730 (patch) | |
tree | eb678f079634c2ec3d50e4a18eedad9331d23512 /lib/Sema/SemaTemplate.cpp | |
parent | 82a0f4e93c055fb12f5ad7c3d146d50eb201308f (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/Sema/SemaTemplate.cpp')
-rw-r--r-- | lib/Sema/SemaTemplate.cpp | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/lib/Sema/SemaTemplate.cpp b/lib/Sema/SemaTemplate.cpp index d0899c89f0..0a319b17f6 100644 --- a/lib/Sema/SemaTemplate.cpp +++ b/lib/Sema/SemaTemplate.cpp @@ -2556,13 +2556,12 @@ bool Sema::CheckTemplateArgumentList(TemplateDecl *Template, if ((*Param)->isTemplateParameterPack()) { if (PartialTemplateArgs && ArgumentPack.empty()) { Converted.push_back(TemplateArgument()); - } else if (ArgumentPack.empty()) { + } else if (ArgumentPack.empty()) Converted.push_back(TemplateArgument(0, 0)); - } else { - TemplateArgument *PackedArgs - = new (Context) TemplateArgument [ArgumentPack.size()]; - std::copy(ArgumentPack.begin(), ArgumentPack.end(), PackedArgs); - Converted.push_back(TemplateArgument(PackedArgs, ArgumentPack.size())); + else { + Converted.push_back(TemplateArgument::CreatePackCopy(Context, + ArgumentPack.data(), + ArgumentPack.size())); ArgumentPack.clear(); } } |