diff options
Diffstat (limited to 'gcc')
| -rw-r--r-- | gcc/cp/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/cp/decl.c | 17 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 3 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/template/static26.C | 10 | 
4 files changed, 26 insertions, 8 deletions
| diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 35001a0..2cbadcf 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@  2006-06-16  Mark Mitchell  <mark@codesourcery.com> +	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 7db989d..c801111 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 b4cc183..fe2b7e8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@  2006-06-16  Mark Mitchell  <mark@codesourcery.com> +	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 0000000..095248b --- /dev/null +++ b/gcc/testsuite/g++.dg/template/static26.C @@ -0,0 +1,10 @@ +// PR c++/28016 +// { dg-final { scan-assembler-not "computed" } } + +template<class T1, class T2> +struct scalar_divides_assign { +  static const bool computed ; +}; + +template<class T1, class T2> +const bool scalar_divides_assign<T1,T2>::computed = true; | 
