diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2010-03-22 23:12:48 +0000 | 
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2010-03-22 23:12:48 +0000 | 
| commit | 8d04f0604e114e7e399c7dd74e9a03215ac1d07a (patch) | |
| tree | 3d82967e656c9d17c728d6cd522709fb1f7740c1 /clang/lib | |
| parent | d22ed622b3cb1f6f022189befdd5c31a4b66217d (diff) | |
| download | bcm5719-llvm-8d04f0604e114e7e399c7dd74e9a03215ac1d07a.tar.gz bcm5719-llvm-8d04f0604e114e7e399c7dd74e9a03215ac1d07a.zip  | |
A fixed version of r99174 which also includes a test that we emit vtables when
we see an specialization definition ever if we then see a extern template declaration.
llvm-svn: 99226
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 2 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaTemplate.cpp | 11 | 
2 files changed, 11 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 13a7ead76bd..1522d6399a2 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -5889,7 +5889,7 @@ static bool needsVtable(CXXMethodDecl *MD, ASTContext &Context) {      break;    case TSK_ExplicitInstantiationDeclaration: -    return true; //FIXME: This looks wrong. +    return false;    case TSK_ExplicitInstantiationDefinition:      // This is method of a explicit instantiation; mark all of the virtual diff --git a/clang/lib/Sema/SemaTemplate.cpp b/clang/lib/Sema/SemaTemplate.cpp index 434d5563e1b..abe9363352e 100644 --- a/clang/lib/Sema/SemaTemplate.cpp +++ b/clang/lib/Sema/SemaTemplate.cpp @@ -4388,8 +4388,17 @@ Sema::ActOnExplicitInstantiation(Scope *S,    // Instantiate the members of this class template specialization.    Def = cast_or_null<ClassTemplateSpecializationDecl>(                                         Specialization->getDefinition()); -  if (Def) +  if (Def) { +    TemplateSpecializationKind Old_TSK = Def->getTemplateSpecializationKind(); + +    // Fix a TSK_ExplicitInstantiationDeclaration followed by a +    // TSK_ExplicitInstantiationDefinition +    if (Old_TSK == TSK_ExplicitInstantiationDeclaration && +        TSK == TSK_ExplicitInstantiationDefinition) +      Def->setTemplateSpecializationKind(TSK); +      InstantiateClassTemplateSpecializationMembers(TemplateNameLoc, Def, TSK); +  }    return DeclPtrTy::make(Specialization);  }  | 

