diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-10-22 17:36:51 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-10-22 17:36:51 +0000 |
commit | dd8c10fbd87f171e361a53c5835800369170123b (patch) | |
tree | 01415fbc227abaf546d63e765b71653a0692e367 | |
parent | 8523d81f3ed13914cafa953233b79cdd8a3eb75c (diff) |
When we perform name lookup for a template, we may end up finding an
ambiguous name where none of the declarations found are actually
templates. In this case, make sure we clear out the ambiguous-path
data when recomputing the lookup result kind. Fixes PR8439.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@117112 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/clang/Sema/Lookup.h | 5 | ||||
-rw-r--r-- | test/SemaTemplate/member-access-ambig.cpp | 35 |
2 files changed, 40 insertions, 0 deletions
diff --git a/include/clang/Sema/Lookup.h b/include/clang/Sema/Lookup.h index 1c7720abb1..1badca21d2 100644 --- a/include/clang/Sema/Lookup.h +++ b/include/clang/Sema/Lookup.h @@ -365,6 +365,11 @@ public: if (Decls.empty()) { if (ResultKind != NotFoundInCurrentInstantiation) ResultKind = NotFound; + + if (Paths) { + deletePaths(Paths); + Paths = 0; + } } else { AmbiguityKind SavedAK = Ambiguity; ResultKind = Found; diff --git a/test/SemaTemplate/member-access-ambig.cpp b/test/SemaTemplate/member-access-ambig.cpp new file mode 100644 index 0000000000..bf190435ec --- /dev/null +++ b/test/SemaTemplate/member-access-ambig.cpp @@ -0,0 +1,35 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s + +// PR8439 +class A +{ +}; + +class B +{ +public: + A & m; +}; + +class Base +{ +public: + B &f(); +}; + +class Derived1 : public Base { }; + +class Derived2 : public Base { }; + +class X : public B, public Derived2, public Derived1 +{ +public: + virtual void g(); +}; + +void X::g() +{ + m.f<int>(); // expected-error{{no member named 'f' in 'A'}} \ + // expected-error{{expected '(' for function-style cast}} \ + // expected-error{{expected expression}} +} |