aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2018-02-26 20:06:40 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2018-02-26 20:06:40 +0000
commit08735f538cd94d5be5fa1b8ee79bfabc7f530a8a (patch)
tree28763431f2806c40cc932242e482d61d55d6d68c /gcc
parent2bb03eb72f5b55edc6deadc2e0320a046d046fa8 (diff)
downloadgcc-08735f538cd94d5be5fa1b8ee79bfabc7f530a8a.zip
gcc-08735f538cd94d5be5fa1b8ee79bfabc7f530a8a.tar.gz
gcc-08735f538cd94d5be5fa1b8ee79bfabc7f530a8a.tar.bz2
re PR c++/84540 (ICE with alignas in variadic template)
/cp 2018-02-26 Paolo Carlini <paolo.carlini@oracle.com> PR c++/84540 * pt.c (tsubst_attributes): Handle correctly tsubst_attribute returning NULL_TREE. (apply_late_template_attributes): Likewise. /testsuite 2018-02-26 Paolo Carlini <paolo.carlini@oracle.com> PR c++/84540 * g++.dg/cpp0x/alignas14.C: New. * g++.dg/cpp0x/alignas15.C: Likewise. From-SVN: r258012
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog7
-rw-r--r--gcc/cp/pt.c6
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/alignas14.C6
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/alignas15.C6
5 files changed, 27 insertions, 4 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 94f684b..d75f1a8 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,10 @@
+2018-02-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84540
+ * pt.c (tsubst_attributes): Handle correctly tsubst_attribute
+ returning NULL_TREE.
+ (apply_late_template_attributes): Likewise.
+
2018-02-26 Jakub Jelinek <jakub@redhat.com>
PR c++/84557
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 9cf96e9..42fd872 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -10245,9 +10245,8 @@ tsubst_attributes (tree attributes, tree args,
if (subst != t)
{
*p = subst;
- do
+ while (*p)
p = &TREE_CHAIN (*p);
- while (*p);
*p = TREE_CHAIN (t);
continue;
}
@@ -10314,9 +10313,8 @@ apply_late_template_attributes (tree *decl_p, tree attributes, int attr_flags,
*p = TREE_CHAIN (t);
TREE_CHAIN (t) = NULL_TREE;
*q = tsubst_attribute (t, decl_p, args, complain, in_decl);
- do
+ while (*q)
q = &TREE_CHAIN (*q);
- while (*q);
}
else
p = &TREE_CHAIN (t);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 9ebfd3e..f050086 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2018-02-26 Paolo Carlini <paolo.carlini@oracle.com>
+
+ PR c++/84540
+ * g++.dg/cpp0x/alignas14.C: New.
+ * g++.dg/cpp0x/alignas15.C: Likewise.
+
2018-02-26 Jakub Jelinek <jakub@redhat.com>
PR c++/84557
diff --git a/gcc/testsuite/g++.dg/cpp0x/alignas14.C b/gcc/testsuite/g++.dg/cpp0x/alignas14.C
new file mode 100644
index 0000000..498e975
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/alignas14.C
@@ -0,0 +1,6 @@
+// PR c++/84540
+// { dg-do compile { target c++11 } }
+
+template<typename... T> struct alignas(alignof(T)...) A {};
+
+A<> a;
diff --git a/gcc/testsuite/g++.dg/cpp0x/alignas15.C b/gcc/testsuite/g++.dg/cpp0x/alignas15.C
new file mode 100644
index 0000000..7244dce
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/alignas15.C
@@ -0,0 +1,6 @@
+// PR c++/84540
+// { dg-do compile { target c++11 } }
+
+template<typename... T> struct A { enum alignas(alignof(T)...) E {}; };
+
+A<> a;