diff options
Diffstat (limited to 'clang/lib/AST')
-rw-r--r-- | clang/lib/AST/ASTContext.cpp | 15 | ||||
-rw-r--r-- | clang/lib/AST/DeclTemplate.cpp | 15 |
2 files changed, 23 insertions, 7 deletions
diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 66aa363c282..e9bcc04c28a 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -1669,9 +1669,10 @@ ASTContext::getTemplateSpecializationType(TemplateName Template, const TemplateArgument *Args, unsigned NumArgs, QualType Canon) { - if (Canon.isNull()) { - // Build the canonical template specialization type, since no type - // was provided. + if (!Canon.isNull()) + Canon = getCanonicalType(Canon); + else { + // Build the canonical template specialization type. TemplateName CanonTemplate = getCanonicalTemplateName(Template); llvm::SmallVector<TemplateArgument, 4> CanonArgs; CanonArgs.reserve(NumArgs); @@ -1695,16 +1696,16 @@ ASTContext::getTemplateSpecializationType(TemplateName Template, 8); Spec = new (Mem) TemplateSpecializationType(*this, CanonTemplate, CanonArgs.data(), NumArgs, - QualType()); + Canon); Types.push_back(Spec); TemplateSpecializationTypes.InsertNode(Spec, InsertPos); } - Canon = QualType(Spec, 0); + if (Canon.isNull()) + Canon = QualType(Spec, 0); assert(Canon->isDependentType() && "Non-dependent template-id type must have a canonical type"); - } else - Canon = getCanonicalType(Canon); + } // Allocate the (non-canonical) template specialization type, but don't // try to unique it: these types typically have location information that diff --git a/clang/lib/AST/DeclTemplate.cpp b/clang/lib/AST/DeclTemplate.cpp index 4677d17dc93..6b3ea437ab6 100644 --- a/clang/lib/AST/DeclTemplate.cpp +++ b/clang/lib/AST/DeclTemplate.cpp @@ -161,6 +161,21 @@ void ClassTemplateDecl::Destroy(ASTContext& C) { C.Deallocate((void*)this); } +ClassTemplatePartialSpecializationDecl * +ClassTemplateDecl::findPartialSpecialization(QualType T) { + ASTContext &Context = getASTContext(); + typedef llvm::FoldingSet<ClassTemplatePartialSpecializationDecl>::iterator + partial_spec_iterator; + for (partial_spec_iterator P = getPartialSpecializations().begin(), + PEnd = getPartialSpecializations().end(); + P != PEnd; ++P) { + if (Context.hasSameType(Context.getTypeDeclType(&*P), T)) + return &*P; + } + + return 0; +} + QualType ClassTemplateDecl::getInjectedClassNameType(ASTContext &Context) { if (!CommonPtr->InjectedClassNameType.isNull()) return CommonPtr->InjectedClassNameType; |