diff options
| author | Douglas Gregor <dgregor@apple.com> | 2011-02-28 00:04:36 +0000 | 
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2011-02-28 00:04:36 +0000 | 
| commit | 6e068014f0d9b41efa6c13db3f6e64d2cfd16257 (patch) | |
| tree | 141f8099182b1924ae201ce90f681970ff994401 /clang/lib/AST/ASTContext.cpp | |
| parent | 41c6ab538ab6ff6c71164d9c2be8200c46096838 (diff) | |
| download | bcm5719-llvm-6e068014f0d9b41efa6c13db3f6e64d2cfd16257.tar.gz bcm5719-llvm-6e068014f0d9b41efa6c13db3f6e64d2cfd16257.zip | |
When we encounter a dependent template name within a
nested-name-specifier, e.g., 
  T::template apply<U>::
represent the dependent template name specialization as a
DependentTemplateSpecializationType, rather than a
TemplateSpecializationType with a dependent TemplateName.
llvm-svn: 126593
Diffstat (limited to 'clang/lib/AST/ASTContext.cpp')
| -rw-r--r-- | clang/lib/AST/ASTContext.cpp | 12 | 
1 files changed, 7 insertions, 5 deletions
| diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 9c2455034d6..ef9e7b31338 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -2377,7 +2377,8 @@ ASTContext::getDependentTemplateSpecializationType(                                   const IdentifierInfo *Name,                                   unsigned NumArgs,                                   const TemplateArgument *Args) const { -  assert(NNS->isDependent() && "nested-name-specifier must be dependent"); +  assert((!NNS || NNS->isDependent()) &&  +         "nested-name-specifier must be dependent");    llvm::FoldingSetNodeID ID;    DependentTemplateSpecializationType::Profile(ID, *this, Keyword, NNS, @@ -3014,10 +3015,11 @@ ASTContext::getCanonicalNestedNameSpecifier(NestedNameSpecifier *NNS) const {            = T->getAs<DependentTemplateSpecializationType>()) {        NestedNameSpecifier *Prefix          = getCanonicalNestedNameSpecifier(DTST->getQualifier()); -      TemplateName Name -        = getDependentTemplateName(Prefix, DTST->getIdentifier()); -      T = getTemplateSpecializationType(Name,  -                                        DTST->getArgs(), DTST->getNumArgs()); +       +      T = getDependentTemplateSpecializationType(DTST->getKeyword(), +                                                 Prefix, DTST->getIdentifier(), +                                                 DTST->getNumArgs(), +                                                 DTST->getArgs());        T = getCanonicalType(T);      } | 

