aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2011-03-02 21:49:28 -0500
committerJason Merrill <jason@gcc.gnu.org>2011-03-02 21:49:28 -0500
commit79d3d3f46cd4080579490adf05b38cd6338eb573 (patch)
tree87fbfd58163991bd059edb6bb38afc64260b378a /gcc
parent262a7d6bc0820d7aed46a05b2b8b6ef7824bb08f (diff)
downloadgcc-79d3d3f46cd4080579490adf05b38cd6338eb573.zip
gcc-79d3d3f46cd4080579490adf05b38cd6338eb573.tar.gz
gcc-79d3d3f46cd4080579490adf05b38cd6338eb573.tar.bz2
re PR c++/47950 ([C++0x] Internal compiler error: non-dependent declaration as condition causes tsubst_copy_and_build assertion failure.)
PR c++/47950 * parser.c (cp_parser_condition): Don't fold_non_dependent_expr here. From-SVN: r170639
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog3
-rw-r--r--gcc/cp/parser.c3
-rw-r--r--gcc/testsuite/ChangeLog2
-rw-r--r--gcc/testsuite/g++.dg/cpp0x/regress/condition1.C80
4 files changed, 85 insertions, 3 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index b9ad026..264bc7c 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,8 @@
2011-03-02 Jason Merrill <jason@redhat.com>
+ PR c++/47950
+ * parser.c (cp_parser_condition): Don't fold_non_dependent_expr here.
+
PR c++/47774
* tree.c (build_vec_init_elt): Split out from...
(build_vec_init_expr): ...here.
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index c63d5b3..510fcb1 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -8687,9 +8687,6 @@ cp_parser_condition (cp_parser* parser)
if (BRACE_ENCLOSED_INITIALIZER_P (initializer))
maybe_warn_cpp0x (CPP0X_INITIALIZER_LISTS);
- if (!non_constant_p)
- initializer = fold_non_dependent_expr (initializer);
-
/* Process the initializer. */
cp_finish_decl (decl,
initializer, !non_constant_p,
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 328ed9e..7b13922 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,7 @@
2011-03-02 Jason Merrill <jason@redhat.com>
+ * g++.dg/cpp0x/regress/condition1.C: New.
+
* g++.dg/cpp0x/constexpr-ctor9.C: New.
2011-03-01 Jason Merrill <jason@redhat.com>
diff --git a/gcc/testsuite/g++.dg/cpp0x/regress/condition1.C b/gcc/testsuite/g++.dg/cpp0x/regress/condition1.C
new file mode 100644
index 0000000..0346764
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/regress/condition1.C
@@ -0,0 +1,80 @@
+// PR c++/47950
+// { dg-options -std=c++0x }
+
+template <typename T> struct empty
+{
+ // allow success case to build (not relevant to bug)
+ operator bool() { return true; }
+};
+
+template <typename T> struct from_int
+{
+ from_int(int) {}
+
+ // allow success case to build (not relevant to bug)
+ operator bool() { return true; }
+};
+
+template <typename T>
+from_int<T> via_function(T v)
+{
+ return from_int<T>(v);
+}
+
+template <typename T>
+void f()
+{
+ // ********* this section compiles ***********
+
+ // these plain initializers work fine
+ from_int<int> a = 7;
+ from_int<int> b = from_int<int>(7);
+ empty<int> c = empty<int>();
+ from_int<T> ta = 7;
+ from_int<T> tb = from_int<T>(7);
+ empty<T> tc = empty<T>();
+
+ // these dependent condition decls work fine
+ if (empty<T> x = empty<T>())
+ ;
+ if (from_int<T> x = 7)
+ ;
+ if (from_int<T> x = from_int<T>(7))
+ ;
+ if (from_int<T> x = via_function(T()))
+ ;
+
+ // this non-dependent condition decl using conversion works fine
+ if (from_int<int> x = 7)
+ ;
+
+ // these non-dependent condition decls using conversion or braced-
+ // initialization work fine (in c++0x mode only course)
+ #if __GXX_EXPERIMENTAL_CXX0X__
+ if (empty<int> x {})
+ ;
+ if (from_int<int> x {7})
+ ;
+ #endif
+
+ // ********** this section fails in C++0x ***********
+
+ // the following non-dependent condition decls cause an assertion
+ // failure in
+ //
+ // tsubst_copy_and_build, at cp/pt.c:13370
+ //
+ // in C++0x mode
+ //
+ if (empty<int> x = empty<int>())
+ ;
+ if (from_int<int> x = from_int<int>(7))
+ ;
+ if (from_int<int> x = via_function(7))
+ ;
+}
+
+int main()
+{
+ f<int>();
+}