https://gcc.gnu.org/bugzilla/show_bug.cgi?id=94149

            Bug ID: 94149
           Summary: __is_constructible doesn't know about C++20
                    parenthesized init for arrays
           Product: gcc
           Version: 10.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: c++
          Assignee: unassigned at gcc dot gnu.org
          Reporter: redi at gcc dot gnu.org
  Target Milestone: ---

In C++20 this is well-formed:

  using T = int[2];
  T t(1, 2);

which means that std::is_constructible_v<int[2], int, int> should be true.

The FE intrinsic gives the wrong answer, and the std::is_nothrow_constructible
library trait isn't going to work even if the intrinsic starts to give the
right answer.


i.e. this should compile with -std=gnu++2a

#include <type_traits>

int main()
{
  using T = int[2];
  T t(1, 2);

  static_assert(__is_constructible(T, int, int));
  static_assert(std::is_constructible_v<T, int, int>);
  static_assert(std::is_nothrow_constructible_v<T, int, int>);

  return t[0];
}


a.cc: In function 'int main()':
a.cc:8:17: error: static assertion failed
    8 |   static_assert(__is_constructible(T, int, int));
      |                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
a.cc:9:22: error: static assertion failed
    9 |   static_assert(std::is_constructible_v<T, int, int>);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
a.cc:10:22: error: static assertion failed
   10 |   static_assert(std::is_nothrow_constructible_v<T, int, int>);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Reply via email to