diff options
author | David Majnemer <david.majnemer@gmail.com> | 2016-06-30 03:02:03 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2016-06-30 03:02:03 +0000 |
commit | 02d57cc92cb82d1bc48273ceafa4c173f8917e81 (patch) | |
tree | b6e565d5c74f8450c6e98c7d1e7f745392c97544 /clang/test/CodeGenCXX/pr28360.cpp | |
parent | b4b671e4a801d81f5899b73690349ebd69605818 (diff) | |
download | bcm5719-llvm-02d57cc92cb82d1bc48273ceafa4c173f8917e81.tar.gz bcm5719-llvm-02d57cc92cb82d1bc48273ceafa4c173f8917e81.zip |
[MS ABI] Pick an inheritance model if we resolve an overload set
We didn't assign an inheritance model for 'Foo' if the event an
exrepssion like '&Foo::Bar' occured if 'Bar' could resolve to multiple
functions.
Once the overload set is resolved to a particular member, we enforce a
specific inheritance model.
This fixes PR28360.
llvm-svn: 274202
Diffstat (limited to 'clang/test/CodeGenCXX/pr28360.cpp')
-rw-r--r-- | clang/test/CodeGenCXX/pr28360.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/pr28360.cpp b/clang/test/CodeGenCXX/pr28360.cpp new file mode 100644 index 00000000000..5d7e1ae0c1f --- /dev/null +++ b/clang/test/CodeGenCXX/pr28360.cpp @@ -0,0 +1,16 @@ +// RUN: %clang_cc1 %s -emit-llvm -o - -triple i686-pc-win32 | FileCheck %s +struct A { + void Foo(); + void Foo(int); +}; + +using MpTy = void (A::*)(); + +void Bar(const MpTy &); + +void Baz() { Bar(&A::Foo); } + +// CHECK-LABEL: define void @"\01?Baz@@YAXXZ"( +// CHECK: %[[ref_tmp:.*]] = alloca i8*, align 4 +// CHECK: store i8* bitcast (void (%struct.A*)* @"\01?Foo@A@@QAEXXZ" to i8*), i8** %[[ref_tmp]], align 4 +// CHECK: call void @"\01?Bar@@YAXABQ8A@@AEXXZ@Z"(i8** dereferenceable(4) %[[ref_tmp]]) |