]> granicus.if.org Git - clang/commitdiff
Implement [over.ics.rank]p4: A conversion that does not convert an std::nullptr_t...
authorAnders Carlsson <andersca@mac.com>
Fri, 5 Nov 2010 00:12:09 +0000 (00:12 +0000)
committerAnders Carlsson <andersca@mac.com>
Fri, 5 Nov 2010 00:12:09 +0000 (00:12 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@118269 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaOverload.cpp
test/SemaCXX/nullptr.cpp

index af004648599c698a512502b8f10a7be22e6f6dd1..af0456bf361ec77712146e6aebd46aea1c19e588 100644 (file)
@@ -190,6 +190,7 @@ bool StandardConversionSequence::isPointerConversionToBool() const {
       (getFromType()->isPointerType() ||
        getFromType()->isObjCObjectPointerType() ||
        getFromType()->isBlockPointerType() ||
+       getFromType()->isNullPtrType() ||
        First == ICK_Array_To_Pointer || First == ICK_Function_To_Pointer))
     return true;
 
index cc75eab30b64f928a2416aa3df90577dfd408a22..0a0d098e364f6a187bf7d94a5f3414f329980eb3 100644 (file)
@@ -1,8 +1,7 @@
 // RUN: %clang_cc1 -fsyntax-only -verify -std=c++0x -ffreestanding %s
 #include <stdint.h>
 
-// Don't have decltype yet.
-typedef __typeof__(nullptr) nullptr_t;
+typedef decltype(nullptr) nullptr_t;
 
 struct A {};
 
@@ -69,3 +68,19 @@ template <int *PI, void (*PF)(), int A::*PM, void (A::*PMF)()>
 struct T {};
 
 typedef T<nullptr, nullptr, nullptr, nullptr> NT;
+
+namespace test1 { 
+template<typename T, typename U> struct is_same {
+  static const bool value = false;
+};
+
+template<typename T> struct is_same<T, T> {
+  static const bool value = true;
+};
+
+void *g(void*);
+bool g(bool);
+
+// Test that we prefer g(void*) over g(bool).
+static_assert(is_same<decltype(g(nullptr)), void*>::value, "");
+}