diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-02-17 23:15:12 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-02-17 23:15:12 +0000 |
commit | 67a65640918dc52e362181099bfc9044313a99e6 (patch) | |
tree | f1addf579c5492a610c1e1982990cc1ac9410ce0 /clang/lib/AST/DeclTemplate.cpp | |
parent | 79d10a2f4321b5acd275c7145ff5c56f3429fb10 (diff) | |
download | bcm5719-llvm-67a65640918dc52e362181099bfc9044313a99e6.tar.gz bcm5719-llvm-67a65640918dc52e362181099bfc9044313a99e6.zip |
Implement basic parsing and semantic analysis for explicit
specialization of class templates, e.g.,
template<typename T> class X;
template<> class X<int> { /* blah */ };
Each specialization is a different *Decl node (naturally), and can
have different members. We keep track of forward declarations and
definitions as for other class/struct/union types.
This is only the basic framework: we still have to deal with checking
the template headers properly, improving recovery when there are
failures, handling nested name specifiers, etc.
llvm-svn: 64848
Diffstat (limited to 'clang/lib/AST/DeclTemplate.cpp')
-rw-r--r-- | clang/lib/AST/DeclTemplate.cpp | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/clang/lib/AST/DeclTemplate.cpp b/clang/lib/AST/DeclTemplate.cpp index 81ef3ab70e4..e10e270c7d4 100644 --- a/clang/lib/AST/DeclTemplate.cpp +++ b/clang/lib/AST/DeclTemplate.cpp @@ -159,7 +159,7 @@ ClassTemplateSpecializationDecl(DeclContext *DC, SourceLocation L, // class template specializations? SpecializedTemplate->getIdentifier()), SpecializedTemplate(SpecializedTemplate), - NumTemplateArgs(NumTemplateArgs) { + NumTemplateArgs(NumTemplateArgs), SpecializationKind(TSK_Undeclared) { TemplateArgument *Arg = reinterpret_cast<TemplateArgument *>(this + 1); for (unsigned ArgIdx = 0; ArgIdx < NumTemplateArgs; ++ArgIdx, ++Arg) *Arg = TemplateArgs[ArgIdx]; @@ -170,12 +170,16 @@ ClassTemplateSpecializationDecl::Create(ASTContext &Context, DeclContext *DC, SourceLocation L, ClassTemplateDecl *SpecializedTemplate, TemplateArgument *TemplateArgs, - unsigned NumTemplateArgs) { + unsigned NumTemplateArgs, + ClassTemplateSpecializationDecl *PrevDecl) { unsigned Size = sizeof(ClassTemplateSpecializationDecl) + sizeof(TemplateArgument) * NumTemplateArgs; unsigned Align = llvm::AlignOf<ClassTemplateSpecializationDecl>::Alignment; void *Mem = Context.Allocate(Size, Align); - return new (Mem) ClassTemplateSpecializationDecl(DC, L, SpecializedTemplate, - TemplateArgs, - NumTemplateArgs); + ClassTemplateSpecializationDecl *Result + = new (Mem) ClassTemplateSpecializationDecl(DC, L, SpecializedTemplate, + TemplateArgs, NumTemplateArgs); + // FIXME: Do we want a prettier type here? + Context.getTypeDeclType(Result, PrevDecl); + return Result; } |