Implement D1957R0, T* to bool should be considered narrowing.
authorJason Merrill <jason@redhat.com>
Sun, 10 Nov 2019 20:30:03 +0000 (15:30 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Sun, 10 Nov 2019 20:30:03 +0000 (15:30 -0500)
This paper was delayed until the February meeting in Prague so that we could
get a better idea of what the impact on existing code would actually be.  To
that end, I'm implementing it now.

* typeck2.c (check_narrowing): Treat pointer->bool as a narrowing
conversion with -std=c++2a.

From-SVN: r278026

gcc/cp/ChangeLog
gcc/cp/typeck2.c
gcc/testsuite/g++.dg/cpp0x/initlist92.C

index 170ce30e7a5c7bbeedd4afdaa29a7f20030a2bd2..23576ec1a5df0ec1c4923b61c446232c4ff29170 100644 (file)
@@ -1,3 +1,9 @@
+2019-11-10  Jason Merrill  <jason@redhat.com>
+
+       Implement D1957R0, T* to bool should be considered narrowing.
+       * typeck2.c (check_narrowing): Treat pointer->bool as a narrowing
+       conversion with -std=c++2a.
+
 2019-11-08  Marek Polacek  <polacek@redhat.com>
 
        PR c++/92215 - flawed diagnostic for bit-field with non-integral type.
index 7884d423a596ccaf36b375862bc7e88f6076f91c..9fb36fd1ed320321faf1f36dc4282b65780459a4 100644 (file)
@@ -1018,6 +1018,11 @@ check_narrowing (tree type, tree init, tsubst_flags_t complain,
            ok = true;
        }
     }
+  else if (TREE_CODE (type) == BOOLEAN_TYPE
+          && (TYPE_PTR_P (ftype) || TYPE_PTRMEM_P (ftype)))
+    /* This hasn't actually made it into C++20 yet, but let's add it now to get
+       an idea of the impact.  */
+    ok = (cxx_dialect < cxx2a);
 
   bool almost_ok = ok;
   if (!ok && !CONSTANT_CLASS_P (init) && (complain & tf_warning_or_error))
index 81a63182f0e24d410e2649dde89e2b87c4be292b..319264ae2741a4e20b3a6e60785b50f605c5eaa7 100644 (file)
@@ -1,26 +1,13 @@
 // PR c++/64665, DR 1467 
-// { dg-do run { target c++11 } }
+// { dg-do compile { target c++11 } }
 
 #include <string>
-#include <cassert>
 
-bool Test1(bool) 
-{
-  return true;
-}
-bool Test1(std::string)
-{
-  return false;
-}
+bool Test1(bool);
+bool Test1(std::string) = delete;
 
-bool Test2(int)
-{
-  return false;
-}
-bool Test2(std::initializer_list<int>)
-{
-  return true;
-}
+bool Test2(int) = delete;
+bool Test2(std::initializer_list<int>);
 
 struct S 
 { 
@@ -28,28 +15,16 @@ struct S
 private:
     int a;
 };
-bool Test3(int)
-{
-  return true;
-}
-bool Test3(S)
-{
-  return false;
-}
+bool Test3(int);
+bool Test3(S) = delete;
 
-bool Test4(bool) 
-{
-  return false;
-}
-bool Test4(std::initializer_list<std::string>)
-{
-  return true;
-}
+bool Test4(bool) = delete;
+bool Test4(std::initializer_list<std::string>);
 
 int main () 
 {
-  assert ( Test1({"false"}) );
-  assert ( Test2({123}) );
-  assert ( Test3({456}) );
-  assert ( Test4({"false"}) );
+  ( Test1({"false"}) );        // { dg-error "narrowing" "" { target c++2a } }
+  ( Test2({123}) );
+  ( Test3({456}) );
+  ( Test4({"false"}) );
 }