aboutsummaryrefslogtreecommitdiff
path: root/clang/test/CodeGenCXX/member-function-pointers.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-10-18 20:31:03 +0000
committerAnders Carlsson <andersca@mac.com>2009-10-18 20:31:03 +0000
commit9500ad13b0b22bc5e8730aa1d3472f9f5349fefd (patch)
treeaf9b821b4c68eb992de8452a74adfe73b92151e5 /clang/test/CodeGenCXX/member-function-pointers.cpp
parent70e7eadd15506498a909b3ea2bd984e987cc2667 (diff)
downloadllvm-9500ad13b0b22bc5e8730aa1d3472f9f5349fefd.zip
llvm-9500ad13b0b22bc5e8730aa1d3472f9f5349fefd.tar.gz
llvm-9500ad13b0b22bc5e8730aa1d3472f9f5349fefd.tar.bz2
Use CK_BitCast for member function pointer casts. Fixes PR5138.
llvm-svn: 84438
Diffstat (limited to 'clang/test/CodeGenCXX/member-function-pointers.cpp')
-rw-r--r--clang/test/CodeGenCXX/member-function-pointers.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/member-function-pointers.cpp b/clang/test/CodeGenCXX/member-function-pointers.cpp
index 13f7de5..a7c2113 100644
--- a/clang/test/CodeGenCXX/member-function-pointers.cpp
+++ b/clang/test/CodeGenCXX/member-function-pointers.cpp
@@ -71,3 +71,19 @@ namespace PR5177 {
void bar(B1 b2) { while (b2()) ; }
}
+
+// PR5138
+namespace PR5138 {
+ struct foo {
+ virtual void bar(foo *);
+ };
+
+ extern "C" {
+ void baz(foo *);
+ }
+
+ void (foo::*ptr1)(void *) = (void (foo::*)(void *))&foo::bar;
+ void (*ptr2)(void *) = (void (*)(void *))&baz;
+
+ void (foo::*ptr3)(void) = (void (foo::*)(void))&foo::bar;
+}