summaryrefslogtreecommitdiff
path: root/test/CodeGenCXX/member-function-pointers.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-10-03 15:02:02 +0000
committerAnders Carlsson <andersca@mac.com>2009-10-03 15:02:02 +0000
commitf57b4e44d03266f2ec1b427645555ed8952bc830 (patch)
treeb9b021500664c7fcfd1e82d2410eabd10d276599 /test/CodeGenCXX/member-function-pointers.cpp
parent2b3583573ba6b26b605aacaad9a50492fb3d6fe6 (diff)
downloadclang-f57b4e44d03266f2ec1b427645555ed8952bc830.tar.gz
Handle members to function pointers in CGExprConstant.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83264 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGenCXX/member-function-pointers.cpp')
-rw-r--r--test/CodeGenCXX/member-function-pointers.cpp14
1 files changed, 10 insertions, 4 deletions
diff --git a/test/CodeGenCXX/member-function-pointers.cpp b/test/CodeGenCXX/member-function-pointers.cpp
index bf24aea9fc..38c13d2919 100644
--- a/test/CodeGenCXX/member-function-pointers.cpp
+++ b/test/CodeGenCXX/member-function-pointers.cpp
@@ -1,7 +1,7 @@
// RUN: clang-cc %s -emit-llvm -o - -triple=x86_64-apple-darwin9 | FileCheck %s
-struct A { int a; };
-struct B { int b; };
+struct A { int a; void f(); virtual void vf(); };
+struct B { int b; virtual void g(); };
struct C : B, A { };
void (A::*pa)();
@@ -9,6 +9,12 @@ void (A::*volatile vpa)();
void (B::*pb)();
void (C::*pc)();
+// CHECK: @pa2 = global %0 { i64 ptrtoint (void ()* @_ZN1A1fEv to i64), i64 0 }, align 8
+void (A::*pa2)() = &A::f;
+
+// CHECK: @pa3 = global %0 { i64 1, i64 0 }, align 8
+void (A::*pa3)() = &A::vf;
+
void f() {
// CHECK: store i64 0, i64* getelementptr inbounds (%0* @pa, i32 0, i32 0)
// CHECK: store i64 0, i64* getelementptr inbounds (%0* @pa, i32 0, i32 1)
@@ -19,7 +25,7 @@ void f() {
vpa = 0;
// CHECK: store i64 %0, i64* getelementptr inbounds (%0* @pc, i32 0, i32 0)
- // CHECK: [[ADJ:%[a-zA-Z0-9]+]] = add i64 %1, 4
+ // CHECK: [[ADJ:%[a-zA-Z0-9]+]] = add i64 %1, 16
// CHECK: store i64 [[ADJ]], i64* getelementptr inbounds (%0* @pc, i32 0, i32 1)
- pc = pa;
+ pc = pa;
}