From: Mark Mitchell Date: Sat, 17 Jun 2006 01:11:34 +0000 (+0000) Subject: re PR c++/28016 (emitting template constant) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=da71e18caeb8bcc6c85c7785c137ee0f99516fb4;p=gcc.git re PR c++/28016 (emitting template constant) PR c++/28016 * decl.c (cp_finsh_decl): Do not emit uninstantiated static data members. PR c++/28016 * g++.dg/template/static26.C: New test. From-SVN: r114739 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 35001a03a47..2cbadcfd11f 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2006-06-16 Mark Mitchell + PR c++/28016 + * decl.c (cp_finsh_decl): Do not emit uninstantiated static data + members. + PR c++/27979 * call.c (standard_conversion): Strip cv-qualifiers from bitfield types. diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 7db989d82a5..c80111145bd 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -5207,16 +5207,17 @@ cp_finish_decl (tree decl, tree init, bool init_const_expr_p, if (at_function_scope_p ()) add_decl_expr (decl); - if (TREE_CODE (decl) == VAR_DECL) - layout_var_decl (decl); - - /* Output the assembler code and/or RTL code for variables and functions, - unless the type is an undefined structure or union. - If not, it will get done when the type is completed. */ - if (TREE_CODE (decl) == VAR_DECL || TREE_CODE (decl) == FUNCTION_DECL) + /* Let the middle end know about variables and functions -- but not + static data members in uninstantiated class templates. */ + if (!saved_processing_template_decl + && (TREE_CODE (decl) == VAR_DECL + || TREE_CODE (decl) == FUNCTION_DECL)) { if (TREE_CODE (decl) == VAR_DECL) - maybe_commonize_var (decl); + { + layout_var_decl (decl); + maybe_commonize_var (decl); + } make_rtl_for_nonlocal_decl (decl, init, asmspec); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b4cc183d964..fe2b7e8b398 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2006-06-16 Mark Mitchell + PR c++/28016 + * g++.dg/template/static26.C: New test. + PR c++/27979 * g++.dg/expr/bitfield2.C: New test. diff --git a/gcc/testsuite/g++.dg/template/static26.C b/gcc/testsuite/g++.dg/template/static26.C new file mode 100644 index 00000000000..095248bace4 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/static26.C @@ -0,0 +1,10 @@ +// PR c++/28016 +// { dg-final { scan-assembler-not "computed" } } + +template +struct scalar_divides_assign { + static const bool computed ; +}; + +template +const bool scalar_divides_assign::computed = true;