aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2019-12-11 19:44:02 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2019-12-11 19:44:02 +0100
commit3455115379cef3a84ce8154b6c4316ed7585f73f (patch)
tree5b7319588d18fd1066a4ea5b9d073dccdce3f506 /gcc
parentc20f7e9971d35b89f17ee6a1bc8ab2462288adda (diff)
downloadgcc-3455115379cef3a84ce8154b6c4316ed7585f73f.zip
gcc-3455115379cef3a84ce8154b6c4316ed7585f73f.tar.gz
gcc-3455115379cef3a84ce8154b6c4316ed7585f73f.tar.bz2
re PR c++/92869 (C++17 wrongly reports aggregate type as not-aggregate (when explicitly defaulted ctors are added))
PR c++/92869 * class.c (finish_struct): For C++17 and earlier, check type_has_user_provided_or_explicit_constructor rather than TYPE_HAS_USER_CONSTRUCTOR whether to set CLASSTYPE_NON_AGGREGATE. * g++.dg/cpp0x/aggr3.C: New test. From-SVN: r279241
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog7
-rw-r--r--gcc/cp/class.c8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/aggr3.C20
4 files changed, 39 insertions, 1 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 5a2ba31..d8a6ae3 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,10 @@
+2019-12-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92869
+ * class.c (finish_struct): For C++17 and earlier, check
+ type_has_user_provided_or_explicit_constructor rather than
+ TYPE_HAS_USER_CONSTRUCTOR whether to set CLASSTYPE_NON_AGGREGATE.
+
2019-12-11 Marek Polacek <polacek@redhat.com>
PR c++/92878 - Parenthesized init of aggregates in new-expression.
diff --git a/gcc/cp/class.c b/gcc/cp/class.c
index a8c6b1c..9b0cf50 100644
--- a/gcc/cp/class.c
+++ b/gcc/cp/class.c
@@ -7474,7 +7474,13 @@ finish_struct (tree t, tree attributes)
/* Remember current #pragma pack value. */
TYPE_PRECISION (t) = maximum_field_alignment;
- if (TYPE_HAS_USER_CONSTRUCTOR (t))
+ if (cxx_dialect < cxx2a)
+ {
+ if (!CLASSTYPE_NON_AGGREGATE (t)
+ && type_has_user_provided_or_explicit_constructor (t))
+ CLASSTYPE_NON_AGGREGATE (t) = 1;
+ }
+ else if (TYPE_HAS_USER_CONSTRUCTOR (t))
CLASSTYPE_NON_AGGREGATE (t) = 1;
/* Fix up any variants we've already built. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index aac5a76..0c22a9c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2019-12-11 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/92869
+ * g++.dg/cpp0x/aggr3.C: New test.
+
2019-12-11 Marek Polacek <polacek@redhat.com>
PR c++/92878 - Parenthesized init of aggregates in new-expression.
diff --git a/gcc/testsuite/g++.dg/cpp0x/aggr3.C b/gcc/testsuite/g++.dg/cpp0x/aggr3.C
new file mode 100644
index 0000000..5b06ed0
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/aggr3.C
@@ -0,0 +1,20 @@
+// PR c++/92869
+// { dg-do compile { target c++11 } }
+
+struct A {
+ A () = default;
+ A (const A &) = default;
+ A (A &&) = default;
+ int arr[3];
+};
+
+template <typename T, int N>
+struct B {
+ B () = default;
+ B (const B &) = default;
+ B (B &&) = default;
+ T arr[N];
+};
+
+A a = { { 1, 2, 3 } }; // { dg-error "could not convert" "" { target c++2a } }
+B<int, 3> b = { { 1, 2, 3 } }; // { dg-error "could not convert" "" { target c++2a } }