bool Sema::DiagnoseUnexpandedParameterPack(const DeclarationNameInfo &NameInfo, UnexpandedParameterPackContext UPPC) { // C++0x [temp.variadic]p5: // An appearance of a name of a parameter pack that is not expanded is // ill-formed. switch (NameInfo.getName().getNameKind()) { case DeclarationName::Identifier: case DeclarationName::ObjCZeroArgSelector: case DeclarationName::ObjCOneArgSelector: case DeclarationName::ObjCMultiArgSelector: case DeclarationName::CXXOperatorName: case DeclarationName::CXXLiteralOperatorName: case DeclarationName::CXXUsingDirective: return false; case DeclarationName::CXXConstructorName: case DeclarationName::CXXDestructorName: case DeclarationName::CXXConversionFunctionName: // FIXME: We shouldn't need this null check! if (TypeSourceInfo *TSInfo = NameInfo.getNamedTypeInfo()) return DiagnoseUnexpandedParameterPack(NameInfo.getLoc(), TSInfo, UPPC); if (!NameInfo.getName().getCXXNameType()->containsUnexpandedParameterPack()) return false; break; } SmallVector<UnexpandedParameterPack, 2> Unexpanded; CollectUnexpandedParameterPacksVisitor(Unexpanded) .TraverseType(NameInfo.getName().getCXXNameType()); assert(!Unexpanded.empty() && "Unable to find unexpanded parameter packs"); return DiagnoseUnexpandedParameterPacks(NameInfo.getLoc(), UPPC, Unexpanded); }
// I didn't factor out the common part of this function // into RewriteUtils, because the common part has implicit // dependency on VisitTemplateSpecializationTypeLoc. If in another // transformation we use this utility without implementing // VisitTemplateSpecializationTypeLoc, we will be in trouble. bool RemoveNamespaceRewriteVisitor::VisitCXXDestructorDecl( CXXDestructorDecl *DtorDecl) { if (ConsumerInstance->isForUsingNamedDecls) return true; const DeclContext *Ctx = DtorDecl->getDeclContext(); const CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(Ctx); TransAssert(CXXRD && "Invalid CXXRecordDecl"); std::string Name; if (!ConsumerInstance->getNewNamedDeclName(CXXRD, Name)) return true; // Avoid duplicated VisitDtor. // For example, in the code below: // template<typename T> // class SomeClass { // public: // ~SomeClass<T>() {} // }; // ~SomeClass<T>'s TypeLoc is represented as TemplateSpecializationTypeLoc // In this case, ~SomeClass will be renamed from // VisitTemplateSpecializationTypeLoc. DeclarationNameInfo NameInfo = DtorDecl->getNameInfo(); if ( TypeSourceInfo *TSInfo = NameInfo.getNamedTypeInfo()) { TypeLoc DtorLoc = TSInfo->getTypeLoc(); if (!DtorLoc.isNull() && (DtorLoc.getTypeLocClass() == TypeLoc::TemplateSpecialization)) return true; } ConsumerInstance->RewriteHelper->replaceCXXDestructorDeclName(DtorDecl, Name); return true; }