diff options
author | Marek Polacek <polacek@redhat.com> | 2023-08-25 11:47:54 -0400 |
---|---|---|
committer | Marek Polacek <polacek@redhat.com> | 2023-08-30 14:24:46 -0400 |
commit | 4a92205ef1da044eaf9490e61787836a3abe7d6c (patch) | |
tree | afd2304f639ba3240748dc28e1eef8336dfb43a1 /gcc/value-range.h | |
parent | c121afc3b6c96a1f229ba0c4a4de6bd4b6be9a53 (diff) | |
download | gcc-4a92205ef1da044eaf9490e61787836a3abe7d6c.zip gcc-4a92205ef1da044eaf9490e61787836a3abe7d6c.tar.gz gcc-4a92205ef1da044eaf9490e61787836a3abe7d6c.tar.bz2 |
c++: CWG 2359, wrong copy-init with designated init [PR91319]
This CWG clarifies that designated initializer support direct-initialization.
Just be careful what Note 2 in [dcl.init.aggr]/4.2 says: "If the
initialization is by designated-initializer-clause, its form determines
whether copy-initialization or direct-initialization is performed." Hence
this patch sets CONSTRUCTOR_IS_DIRECT_INIT only when we are dealing with
".x{}", but not ".x = {}".
PR c++/91319
gcc/cp/ChangeLog:
* parser.cc (cp_parser_initializer_list): Set CONSTRUCTOR_IS_DIRECT_INIT
when the designated initializer is of the .x{} form.
gcc/testsuite/ChangeLog:
* g++.dg/cpp2a/desig30.C: New test.
Diffstat (limited to 'gcc/value-range.h')
0 files changed, 0 insertions, 0 deletions