summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorKaelyn Uhrain <rikka@google.com>2014-02-09 21:47:04 +0000
committerKaelyn Uhrain <rikka@google.com>2014-02-09 21:47:04 +0000
commit0e35355c04c9e44dab651a938bb7ee3572c37851 (patch)
tree2936243edefc50c1c155db41588e0414e21733ef /clang
parentd31aaf109efe98823e09594b3ffa9f63e09cf048 (diff)
downloadbcm5719-llvm-0e35355c04c9e44dab651a938bb7ee3572c37851.tar.gz
bcm5719-llvm-0e35355c04c9e44dab651a938bb7ee3572c37851.zip
PR18685: Ignore class template specializations as potential
nested-name-specifiers for typos unless the typo already has a nested-name-specifier that is a template specialization. llvm-svn: 201056
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaLookup.cpp7
-rw-r--r--clang/test/SemaCXX/typo-correction-pt2.cpp16
2 files changed, 23 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaLookup.cpp b/clang/lib/Sema/SemaLookup.cpp
index 8a5c0a5ba7e..1a47340d69a 100644
--- a/clang/lib/Sema/SemaLookup.cpp
+++ b/clang/lib/Sema/SemaLookup.cpp
@@ -4210,6 +4210,12 @@ TypoCorrection Sema::CorrectTypo(const DeclarationNameInfo &TypoName,
KNI != KNIEnd; ++KNI)
Namespaces.AddNameSpecifier(KNI->first);
+ bool SSIsTemplate = false;
+ if (NestedNameSpecifier *NNS =
+ (SS && SS->isValid()) ? SS->getScopeRep() : 0) {
+ if (const Type *T = NNS->getAsType())
+ SSIsTemplate = T->getTypeClass() == Type::TemplateSpecialization;
+ }
for (ASTContext::type_iterator TI = Context.types_begin(),
TIEnd = Context.types_end();
TI != TIEnd; ++TI) {
@@ -4217,6 +4223,7 @@ TypoCorrection Sema::CorrectTypo(const DeclarationNameInfo &TypoName,
CD = CD->getCanonicalDecl();
if (!CD->isDependentType() && !CD->isAnonymousStructOrUnion() &&
!CD->isUnion() && CD->getIdentifier() &&
+ (SSIsTemplate || !isa<ClassTemplateSpecializationDecl>(CD)) &&
(CD->isBeingDefined() || CD->isCompleteDefinition()))
Namespaces.AddNameSpecifier(CD);
}
diff --git a/clang/test/SemaCXX/typo-correction-pt2.cpp b/clang/test/SemaCXX/typo-correction-pt2.cpp
index 65d961085a8..1738bb41b91 100644
--- a/clang/test/SemaCXX/typo-correction-pt2.cpp
+++ b/clang/test/SemaCXX/typo-correction-pt2.cpp
@@ -207,3 +207,19 @@ struct {
int y = x; // expected-error-re {{use of undeclared identifier 'x'{{$}}}}
}
+
+namespace PR18685 {
+template <class C, int I, int J>
+class SetVector {
+ public:
+ SetVector() {}
+};
+
+template <class C, int I>
+class SmallSetVector : public SetVector<C, I, 8> {};
+
+class foo {};
+SmallSetVector<foo*, 2> fooSet;
+}
+
+PR18685::BitVector Map; // expected-error-re {{no type named 'BitVector' in namespace 'PR18685'{{$}}}}
OpenPOWER on IntegriCloud