llvm/clang/test/SemaTemplate/member-access-ambig.cpp

// RUN: %clang_cc1 -fsyntax-only -verify -Wno-unused-comparison %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}}
}

namespace PR11134 {
  template<typename Derived> class A;
  template<typename Derived> class B : A<Derived> {
    typedef A<Derived> Base;
    using Base::member;
    int member;
  };
}

namespace AddrOfMember {
  struct A { int X; };
  typedef int (A::*P);
  template<typename T> struct S : T {
    void f() {
      P(&T::X) // expected-error {{cannot cast from type 'int *' to member pointer type 'P'}}
          == &A::X;
    }
  };

  void g() {
    S<A>().f(); // ok, &T::X is 'int (A::*)', not 'int *', even though T is a base class
  }

  struct B : A { static int X; };
  void h() {
    S<B>().f(); // expected-note {{here}}
  }
}