diff options
| author | John McCall <rjmccall@apple.com> | 2010-08-28 20:17:00 +0000 |
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2010-08-28 20:17:00 +0000 |
| commit | fb3f9ba969e3ec5b31d0286f53f978363c5d9623 (patch) | |
| tree | 7c600bac9f1735044e2d033184eeefb79fa4c7b5 | |
| parent | d13b1a3581baf589d5491923e0ec88c6ae0aa7dc (diff) | |
| download | bcm5719-llvm-fb3f9ba969e3ec5b31d0286f53f978363c5d9623.tar.gz bcm5719-llvm-fb3f9ba969e3ec5b31d0286f53f978363c5d9623.zip | |
If filtering a lookup result leaves it ambiguous, keep the ambiguity
kind. Fixes PR7252.
llvm-svn: 112383
| -rw-r--r-- | clang/include/clang/Sema/Lookup.h | 9 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaTemplate.cpp | 7 | ||||
| -rw-r--r-- | clang/test/SemaTemplate/temp.cpp | 18 |
3 files changed, 29 insertions, 5 deletions
diff --git a/clang/include/clang/Sema/Lookup.h b/clang/include/clang/Sema/Lookup.h index c9b090ae228..1c7720abb1e 100644 --- a/clang/include/clang/Sema/Lookup.h +++ b/clang/include/clang/Sema/Lookup.h @@ -366,10 +366,15 @@ public: if (ResultKind != NotFoundInCurrentInstantiation) ResultKind = NotFound; } else { + AmbiguityKind SavedAK = Ambiguity; ResultKind = Found; resolveKind(); - - if (Paths && (ResultKind != Ambiguous)) { + + // If we didn't make the lookup unambiguous, restore the old + // ambiguity kind. + if (ResultKind == Ambiguous) { + Ambiguity = SavedAK; + } else if (Paths) { deletePaths(Paths); Paths = 0; } diff --git a/clang/lib/Sema/SemaTemplate.cpp b/clang/lib/Sema/SemaTemplate.cpp index 09656bcd915..2cbf3073a46 100644 --- a/clang/lib/Sema/SemaTemplate.cpp +++ b/clang/lib/Sema/SemaTemplate.cpp @@ -141,8 +141,13 @@ TemplateNameKind Sema::isTemplateName(Scope *S, LookupOrdinaryName); LookupTemplateName(R, S, SS, ObjectType, EnteringContext, MemberOfUnknownSpecialization); - if (R.empty() || R.isAmbiguous()) { + if (R.empty()) return TNK_Non_template; + if (R.isAmbiguous()) { + // Suppress diagnostics; we'll redo this lookup later. R.suppressDiagnostics(); + + // FIXME: we might have ambiguous templates, in which case we + // should at least parse them properly! return TNK_Non_template; } diff --git a/clang/test/SemaTemplate/temp.cpp b/clang/test/SemaTemplate/temp.cpp index 961b9c873ab..e037f0f0713 100644 --- a/clang/test/SemaTemplate/temp.cpp +++ b/clang/test/SemaTemplate/temp.cpp @@ -1,5 +1,19 @@ // RUN: %clang_cc1 -fsyntax-only -verify %s -// p3 -template<typename T> int foo(T), bar(T, T); // expected-error{{single entity}} +namespace test0 { + // p3 + template<typename T> int foo(T), bar(T, T); // expected-error{{single entity}} +} + +// PR7252 +namespace test1 { + namespace A { template<typename T> struct Base { typedef T t; }; } // expected-note {{member found}} + namespace B { template<typename T> struct Base { typedef T t; }; } // expected-note {{member found}} + + template<typename T> struct Derived : A::Base<char>, B::Base<int> { + // FIXME: the syntax error here is unfortunate + typename Derived::Base<float>::t x; // expected-error {{found in multiple base classes of different types}} \ + // expected-error {{expected member name or ';'}} + }; +} |

