diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-12-16 01:40:04 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-12-16 01:40:04 +0000 |
| commit | 6ab34afc4ebeb05e47531c379935031949a2d7e7 (patch) | |
| tree | 7b3f2407ea85b7404312b6b34b82d5952b818276 /clang/lib | |
| parent | e9afc740a8f6d747d899c3d2322db9828846aaeb (diff) | |
| download | bcm5719-llvm-6ab34afc4ebeb05e47531c379935031949a2d7e7.tar.gz bcm5719-llvm-6ab34afc4ebeb05e47531c379935031949a2d7e7.zip | |
Fix a regression I caused in r121930. It turns out that
DeclarationNameInfo instances don't always have a non-NULL
TypeSourceInfo?
llvm-svn: 121940
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaTemplateVariadic.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaTemplateVariadic.cpp b/clang/lib/Sema/SemaTemplateVariadic.cpp index 2338b5bfbca..07873efdac6 100644 --- a/clang/lib/Sema/SemaTemplateVariadic.cpp +++ b/clang/lib/Sema/SemaTemplateVariadic.cpp @@ -221,15 +221,19 @@ bool Sema::DiagnoseUnexpandedParameterPack(const DeclarationNameInfo &NameInfo, case DeclarationName::CXXConstructorName: case DeclarationName::CXXDestructorName: case DeclarationName::CXXConversionFunctionName: - if (!NameInfo.getNamedTypeInfo()->getType() - ->containsUnexpandedParameterPack()) + // FIXME: We shouldn't need this! + if (TypeSourceInfo *TSInfo = NameInfo.getNamedTypeInfo()) + return DiagnoseUnexpandedParameterPack(NameInfo.getLoc(), TSInfo, UPPC); + + if (!NameInfo.getName().getCXXNameType()->containsUnexpandedParameterPack()) return false; + break; } llvm::SmallVector<UnexpandedParameterPack, 2> Unexpanded; CollectUnexpandedParameterPacksVisitor(Unexpanded) - .TraverseTypeLoc(NameInfo.getNamedTypeInfo()->getTypeLoc()); + .TraverseType(NameInfo.getName().getCXXNameType()); assert(!Unexpanded.empty() && "Unable to find unexpanded parameter packs"); DiagnoseUnexpandedParameterPacks(*this, NameInfo.getLoc(), UPPC, Unexpanded); return true; |

