summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-12-16 01:40:04 +0000
committerDouglas Gregor <dgregor@apple.com>2010-12-16 01:40:04 +0000
commit6ab34afc4ebeb05e47531c379935031949a2d7e7 (patch)
tree7b3f2407ea85b7404312b6b34b82d5952b818276 /clang/lib
parente9afc740a8f6d747d899c3d2322db9828846aaeb (diff)
downloadbcm5719-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.cpp10
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;
OpenPOWER on IntegriCloud