From: Douglas Gregor Date: Sun, 13 Dec 2009 21:29:20 +0000 (+0000) Subject: Don't assume that all conversions to a void pointer are converting X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=335b07ae470045dab25739ded6541744ec8fe40b;p=clang Don't assume that all conversions to a void pointer are converting from a PointerType. Fixes PR5756. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91253 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaOverload.cpp b/lib/Sema/SemaOverload.cpp index e498c71b9b..2f6300d5bc 100644 --- a/lib/Sema/SemaOverload.cpp +++ b/lib/Sema/SemaOverload.cpp @@ -1723,26 +1723,31 @@ Sema::CompareStandardConversionSequences(const StandardConversionSequence& SCS1, if (SCS2.First == ICK_Array_To_Pointer) FromType2 = Context.getArrayDecayedType(FromType2); - QualType FromPointee1 - = FromType1->getAs()->getPointeeType().getUnqualifiedType(); - QualType FromPointee2 - = FromType2->getAs()->getPointeeType().getUnqualifiedType(); - - if (IsDerivedFrom(FromPointee2, FromPointee1)) - return ImplicitConversionSequence::Better; - else if (IsDerivedFrom(FromPointee1, FromPointee2)) - return ImplicitConversionSequence::Worse; - - // Objective-C++: If one interface is more specific than the - // other, it is the better one. - const ObjCInterfaceType* FromIface1 = FromPointee1->getAs(); - const ObjCInterfaceType* FromIface2 = FromPointee2->getAs(); - if (FromIface1 && FromIface1) { - if (Context.canAssignObjCInterfaces(FromIface2, FromIface1)) - return ImplicitConversionSequence::Better; - else if (Context.canAssignObjCInterfaces(FromIface1, FromIface2)) - return ImplicitConversionSequence::Worse; - } + if (const PointerType *FromPointer1 = FromType1->getAs()) + if (const PointerType *FromPointer2 = FromType2->getAs()) { + QualType FromPointee1 + = FromPointer1->getPointeeType().getUnqualifiedType(); + QualType FromPointee2 + = FromPointer2->getPointeeType().getUnqualifiedType(); + + if (IsDerivedFrom(FromPointee2, FromPointee1)) + return ImplicitConversionSequence::Better; + else if (IsDerivedFrom(FromPointee1, FromPointee2)) + return ImplicitConversionSequence::Worse; + + // Objective-C++: If one interface is more specific than the + // other, it is the better one. + const ObjCInterfaceType* FromIface1 + = FromPointee1->getAs(); + const ObjCInterfaceType* FromIface2 + = FromPointee2->getAs(); + if (FromIface1 && FromIface1) { + if (Context.canAssignObjCInterfaces(FromIface2, FromIface1)) + return ImplicitConversionSequence::Better; + else if (Context.canAssignObjCInterfaces(FromIface1, FromIface2)) + return ImplicitConversionSequence::Worse; + } + } } // Compare based on qualification conversions (C++ 13.3.3.2p3, diff --git a/test/SemaCXX/overload-call.cpp b/test/SemaCXX/overload-call.cpp index 0936b947c4..5d2718208f 100644 --- a/test/SemaCXX/overload-call.cpp +++ b/test/SemaCXX/overload-call.cpp @@ -291,3 +291,13 @@ void f(SR) { } void g(opt o) { f(o); } + + +namespace PR5756 { + int &a(void*, int); + float &a(void*, float); + void b() { + int &ir = a(0,0); + (void)ir; + } +}