From: Douglas Gregor Date: Fri, 15 Apr 2011 20:45:44 +0000 (+0000) Subject: For the purposes of overload resolution, consider a conversion from an X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f9af524b818f7a6f0ed812334482a5d657b2ff5b;p=clang For the purposes of overload resolution, consider a conversion from an Objective-C pointer to void* as a "conversion to void*". This allows us to prefer an Objective-C object pointer conversion to a superclass object pointer over an Objective-C object pointer conversion to cv-void*. Fixes PR9735. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@129603 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaOverload.cpp b/lib/Sema/SemaOverload.cpp index 57338f255c..9caf673601 100644 --- a/lib/Sema/SemaOverload.cpp +++ b/lib/Sema/SemaOverload.cpp @@ -240,7 +240,7 @@ isPointerConversionToVoidPointer(ASTContext& Context) const { if (First == ICK_Array_To_Pointer) FromType = Context.getArrayDecayedType(FromType); - if (Second == ICK_Pointer_Conversion && FromType->isPointerType()) + if (Second == ICK_Pointer_Conversion && FromType->isAnyPointerType()) if (const PointerType* ToPtrType = ToType->getAs()) return ToPtrType->getPointeeType()->isVoidType(); diff --git a/test/SemaObjCXX/overload.mm b/test/SemaObjCXX/overload.mm index a40248e6cd..09cd3ec45c 100644 --- a/test/SemaObjCXX/overload.mm +++ b/test/SemaObjCXX/overload.mm @@ -149,3 +149,13 @@ namespace rdar8734046 { f2(a); } } + +namespace PR9735 { + int &f3(const A*); + float &f3(const void*); + + void test_f(B* b, const B* bc) { + int &ir1 = f3(b); + int &ir2 = f3(bc); + } +}