// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s struct X { }; template T& lvalue(); template T&& xvalue(); template T prvalue(); // In a .* expression whose object expression is an rvalue, the // program is ill-formed if the second operand is a pointer to member // function with ref-qualifier &. In a ->* expression or in a .* // expression whose object expression is an lvalue, the program is // ill-formed if the second operand is a pointer to member function // with ref-qualifier &&. void test(X *xp, int (X::*pmf)(int), int (X::*l_pmf)(int) &, int (X::*r_pmf)(int) &&) { // No ref-qualifier. (lvalue().*pmf)(17); (xvalue().*pmf)(17); (prvalue().*pmf)(17); (xp->*pmf)(17); // Lvalue ref-qualifier. (lvalue().*l_pmf)(17); (xvalue().*l_pmf)(17); // expected-error-re{{pointer-to-member function type 'int (X::*)(int){{( __attribute__\(\(thiscall\)\))?}} &' can only be called on an lvalue}} (prvalue().*l_pmf)(17); // expected-error-re{{pointer-to-member function type 'int (X::*)(int){{( __attribute__\(\(thiscall\)\))?}} &' can only be called on an lvalue}} (xp->*l_pmf)(17); // Rvalue ref-qualifier. (lvalue().*r_pmf)(17); // expected-error-re{{pointer-to-member function type 'int (X::*)(int){{( __attribute__\(\(thiscall\)\))?}} &&' can only be called on an rvalue}} (xvalue().*r_pmf)(17); (prvalue().*r_pmf)(17); (xp->*r_pmf)(17); // expected-error-re{{pointer-to-member function type 'int (X::*)(int){{( __attribute__\(\(thiscall\)\))?}} &&' can only be called on an rvalue}} }