diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-11-01 18:49:26 +0000 |
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-11-01 18:49:26 +0000 |
| commit | ca766296180af49f525a04eeef6b64f6064b7035 (patch) | |
| tree | ce8973d02c0a1f47698100ef9ed2bb6d2ad32291 /clang/test/SemaCXX | |
| parent | b524d906fe4dd4c66e606011f19f690f20c791fa (diff) | |
| download | bcm5719-llvm-ca766296180af49f525a04eeef6b64f6064b7035.tar.gz bcm5719-llvm-ca766296180af49f525a04eeef6b64f6064b7035.zip | |
Emit error when using a bound member function for something other than calling it.
Also avoids IRGen crashes due to accepting invalid code.
llvm-svn: 117943
Diffstat (limited to 'clang/test/SemaCXX')
| -rw-r--r-- | clang/test/SemaCXX/ptrtomember.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/ptrtomember.cpp b/clang/test/SemaCXX/ptrtomember.cpp index e84e931ee80..f26f13f19cd 100644 --- a/clang/test/SemaCXX/ptrtomember.cpp +++ b/clang/test/SemaCXX/ptrtomember.cpp @@ -16,3 +16,17 @@ struct S2 { }; int S2::*pf = &S2::bitfield; // expected-error {{address of bit-field requested}} + +struct S3 { + void m(); +}; + +void f3(S3* p, void (S3::*m)()) { + p->*m; // expected-error {{a bound member function may only be used to call it}} + (void)(p->*m); // expected-error {{a bound member function may only be used to call it}} + (void)(void*)(p->*m); // expected-error {{a bound member function may only be used to call it}} + (void)reinterpret_cast<void*>(p->*m); // expected-error {{a bound member function may only be used to call it}} + if (p->*m) {} // expected-error {{a bound member function may only be used to call it}} + + p->m; // expected-error {{a bound member function may only be used to call it}} +} |

