From: Jason Merrill Date: Fri, 3 Apr 2009 17:24:46 +0000 (-0400) Subject: re PR c++/39608 ('expr' cannot appear in a constant-expression.) X-Git-Tag: releases/gcc-4.5.0~6923 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=b77ba909af773561e808c3d7cf64c46a8112dcab;p=thirdparty%2Fgcc.git re PR c++/39608 ('expr' cannot appear in a constant-expression.) PR c++/39608 * semantics.c (finish_id_expression): Don't assume a dependent member of the current instantiation isn't a valid integral constant expression. Check dependent_scope_p. * pt.c (dependent_scope_p): Check TYPE_P. From-SVN: r145508 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 5cba9d0747a9..9bc48b6baf43 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,12 @@ +2009-04-03 Jason Merrill + + PR c++/39608 + * semantics.c (finish_id_expression): Don't assume a dependent + member of the current instantiation isn't a valid integral + constant expression. Check dependent_scope_p. + * pt.c (dependent_scope_p): Check TYPE_P. + (tsubst_copy): If args is null, just return. + 2009-04-02 Jason Merrill PR c++/25185 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 8b2fa6e7e17c..90be6bcf9c05 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -9999,7 +9999,7 @@ tsubst_copy (tree t, tree args, tsubst_flags_t complain, tree in_decl) enum tree_code code; tree r; - if (t == NULL_TREE || t == error_mark_node) + if (t == NULL_TREE || t == error_mark_node || args == NULL_TREE) return t; code = TREE_CODE (t); @@ -16168,7 +16168,8 @@ dependent_type_p (tree type) bool dependent_scope_p (tree scope) { - return dependent_type_p (scope) && !currently_open_class (scope); + return (scope && TYPE_P (scope) && dependent_type_p (scope) + && !currently_open_class (scope)); } /* Returns TRUE if EXPRESSION is dependent, according to CRITERION. */ diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index ee8c0ccfafa4..337b6373b283 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -2857,11 +2857,6 @@ finish_id_expression (tree id_expression, dependent. */ if (scope) { - /* Since this name was dependent, the expression isn't - constant -- yet. No error is issued because it might - be constant when things are instantiated. */ - if (integral_constant_expression_p) - *non_integral_constant_expression_p = true; if (TYPE_P (scope)) { if (address_p && done) @@ -2869,7 +2864,7 @@ finish_id_expression (tree id_expression, done, address_p, template_p, template_arg_p); - else if (dependent_type_p (scope)) + else if (dependent_scope_p (scope)) decl = build_qualified_name (/*type=*/NULL_TREE, scope, id_expression, diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ded87d66bdad..2d697b1ea973 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-04-03 Jason Merrill + + PR c++/39608 + * g++.dg/template/const2.C: New test. + 2009-04-03 Richard Guenther PR tree-optimization/2480 diff --git a/gcc/testsuite/g++.dg/template/const2.C b/gcc/testsuite/g++.dg/template/const2.C new file mode 100644 index 000000000000..5188fe29d10e --- /dev/null +++ b/gcc/testsuite/g++.dg/template/const2.C @@ -0,0 +1,16 @@ +// PR c++/39608 +// We were improperly considering dependent members of the current +// instantiation to be non-constant (and therefore invalid template +// non-type arguments). + +template +struct C {}; + +template +struct A +{ + static const T x = 1; + C::x> c; // { dg-bogus "invalid" } +}; + +A a;