mirror of
https://github.com/intel/llvm.git
synced 2026-02-02 02:00:03 +08:00
[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
This commit is contained in:
@@ -13021,6 +13021,9 @@ Expr *Sema::FixOverloadedFunctionReference(Expr *E, DeclAccessPair Found,
|
||||
= Context.getTypeDeclType(cast<RecordDecl>(Method->getDeclContext()));
|
||||
QualType MemPtrType
|
||||
= Context.getMemberPointerType(Fn->getType(), ClassType.getTypePtr());
|
||||
// Under the MS ABI, lock down the inheritance model now.
|
||||
if (Context.getTargetInfo().getCXXABI().isMicrosoft())
|
||||
(void)isCompleteType(UnOp->getOperatorLoc(), MemPtrType);
|
||||
|
||||
return new (Context) UnaryOperator(SubExpr, UO_AddrOf, MemPtrType,
|
||||
VK_RValue, OK_Ordinary,
|
||||
|
||||
16
clang/test/CodeGenCXX/pr28360.cpp
Normal file
16
clang/test/CodeGenCXX/pr28360.cpp
Normal file
@@ -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]])
|
||||
Reference in New Issue
Block a user