From: Jason Merrill Date: Thu, 3 Mar 2011 02:49:28 +0000 (-0500) Subject: re PR c++/47950 ([C++0x] Internal compiler error: non-dependent declaration as condit... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;ds=sidebyside;h=79d3d3f46cd4080579490adf05b38cd6338eb573;p=gcc.git 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 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index b9ad026d3c2..264bc7c7ed9 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,8 @@ 2011-03-02 Jason Merrill + 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 c63d5b3a049..510fcb11179 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 328ed9e468e..7b139222f3a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,7 @@ 2011-03-02 Jason Merrill + * g++.dg/cpp0x/regress/condition1.C: New. + * g++.dg/cpp0x/constexpr-ctor9.C: New. 2011-03-01 Jason Merrill 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 00000000000..0346764f79b --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/regress/condition1.C @@ -0,0 +1,80 @@ +// PR c++/47950 +// { dg-options -std=c++0x } + +template struct empty +{ + // allow success case to build (not relevant to bug) + operator bool() { return true; } +}; + +template struct from_int +{ + from_int(int) {} + + // allow success case to build (not relevant to bug) + operator bool() { return true; } +}; + +template +from_int via_function(T v) +{ + return from_int(v); +} + +template +void f() +{ + // ********* this section compiles *********** + + // these plain initializers work fine + from_int a = 7; + from_int b = from_int(7); + empty c = empty(); + from_int ta = 7; + from_int tb = from_int(7); + empty tc = empty(); + + // these dependent condition decls work fine + if (empty x = empty()) + ; + if (from_int x = 7) + ; + if (from_int x = from_int(7)) + ; + if (from_int x = via_function(T())) + ; + + // this non-dependent condition decl using conversion works fine + if (from_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 x {}) + ; + if (from_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 x = empty()) + ; + if (from_int x = from_int(7)) + ; + if (from_int x = via_function(7)) + ; +} + +int main() +{ + f(); +}