From: Jason Merrill Date: Sun, 10 Nov 2019 20:30:03 +0000 (-0500) Subject: Implement D1957R0, T* to bool should be considered narrowing. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2806ecbdc8054ef9f3968577806b007baefad4e6;p=gcc.git Implement D1957R0, T* to bool should be considered narrowing. 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 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 170ce30e7a5..23576ec1a5d 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2019-11-10 Jason Merrill + + 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 PR c++/92215 - flawed diagnostic for bit-field with non-integral type. diff --git a/gcc/cp/typeck2.c b/gcc/cp/typeck2.c index 7884d423a59..9fb36fd1ed3 100644 --- a/gcc/cp/typeck2.c +++ b/gcc/cp/typeck2.c @@ -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)) diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist92.C b/gcc/testsuite/g++.dg/cpp0x/initlist92.C index 81a63182f0e..319264ae274 100644 --- a/gcc/testsuite/g++.dg/cpp0x/initlist92.C +++ b/gcc/testsuite/g++.dg/cpp0x/initlist92.C @@ -1,26 +1,13 @@ // PR c++/64665, DR 1467 -// { dg-do run { target c++11 } } +// { dg-do compile { target c++11 } } #include -#include -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) -{ - return true; -} +bool Test2(int) = delete; +bool Test2(std::initializer_list); 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) -{ - return true; -} +bool Test4(bool) = delete; +bool Test4(std::initializer_list); 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"}) ); }