diff options
author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2010-01-11 15:56:56 +0000 |
---|---|---|
committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2010-01-11 15:56:56 +0000 |
commit | 9a8dd0db89f7d6cc945bd4a5173dd2a3bf8fd94d (patch) | |
tree | 27cb91bbd1a49415fd0c3d6c30ad1f447e609546 /clang/test | |
parent | 9ce5b5134dbc9df7e4d6f2a938f84a499ad81096 (diff) | |
download | bcm5719-llvm-9a8dd0db89f7d6cc945bd4a5173dd2a3bf8fd94d.tar.gz bcm5719-llvm-9a8dd0db89f7d6cc945bd4a5173dd2a3bf8fd94d.zip |
Make Clang complain about taking the address of an unqualified member function. Fixes PR5985.
llvm-svn: 93150
Diffstat (limited to 'clang/test')
-rw-r--r-- | clang/test/SemaCXX/member-pointer.cpp | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/clang/test/SemaCXX/member-pointer.cpp b/clang/test/SemaCXX/member-pointer.cpp index 65d05eb5af7..3d9d5b5ebbb 100644 --- a/clang/test/SemaCXX/member-pointer.cpp +++ b/clang/test/SemaCXX/member-pointer.cpp @@ -80,7 +80,7 @@ void g() { void (HasMembers::*pmf)() = &HasMembers::f; void (*pnf)() = &Fake::f; - &hm.f; // FIXME: needs diagnostic expected-warning{{result unused}} + &hm.f; // expected-error {{must explicitly qualify}} expected-warning{{result unused}} void (HasMembers::*pmgv)() = &HasMembers::g; void (HasMembers::*pmgi)(int) = &HasMembers::g; @@ -136,3 +136,15 @@ void i() { OverloadsPtrMem m; int foo = m->*"Awesome!"; } + +namespace pr5985 { + struct c { + void h(); + void f() { + void (c::*p)(); + p = &h; // expected-error {{must explicitly qualify}} + p = &this->h; // expected-error {{must explicitly qualify}} + p = &(*this).h; // expected-error {{must explicitly qualify}} + } + }; +} |