diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 0271eb9408b1..9e7675570e57 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2010-02-01 Tobias Burnus + + PR fortran/42922 + * decl.c (variable_decl): Allow default initializer in + TYPE declarations in PURE functions. + 2010-01-31 Janus Weil PR fortran/42888 @@ -12,10 +18,10 @@ 2010-01-31 Paul Thomas - PR fortran/38324 + PR fortran/38324 * expr.c (gfc_get_full_arrayspec_from_expr): New function. * gfortran.h : Add prototype for above. - * trans-expr.c (gfc_trans_alloc_subarray_assign): New function. + * trans-expr.c (gfc_trans_alloc_subarray_assign): New function. (gfc_trans_subcomponent_assign): Call new function to replace the code to deal with allocatable components. * trans-intrinsic.c (gfc_conv_intrinsic_bound): Call diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index 9f65fe41eec0..015d6a4ef941 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -1809,7 +1809,8 @@ variable_decl (int elem) m = MATCH_ERROR; } - if (current_attr.flavor != FL_PARAMETER && gfc_pure (NULL)) + if (current_attr.flavor != FL_PARAMETER && gfc_pure (NULL) + && gfc_state_stack->state != COMP_DERIVED) { gfc_error ("Initialization of variable at %C is not allowed in " "a PURE procedure"); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a2d83441672d..c68fe114b381 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-02-01 Tobias Burnus + + PR fortran/42922 + * gfortran.dg/pure_initializer_3.f90: News test. + 2010-01-31 Janus Weil PR fortran/42888 @@ -15,9 +20,9 @@ 2010-01-31 Paul Thomas - PR fortran/38324 - * gfortran.dg/alloc_comp_basics_1.f90: Remove option -O2. - * gfortran.dg/alloc_comp_bounds_1.f90: New test. + PR fortran/38324 + * gfortran.dg/alloc_comp_basics_1.f90: Remove option -O2. + * gfortran.dg/alloc_comp_bounds_1.f90: New test. 2010-01-30 Paolo Bonzini diff --git a/gcc/testsuite/gfortran.dg/pure_initializer_3.f90 b/gcc/testsuite/gfortran.dg/pure_initializer_3.f90 new file mode 100644 index 000000000000..91ec178f14d4 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pure_initializer_3.f90 @@ -0,0 +1,14 @@ +! { dg-do compile } +! +! PR fortran/42922 +! +! Contributed by mrestelli@gmail.com +! +pure subroutine psub() + implicit none + type ilist + integer :: i = 0 + end type ilist + type(ilist) :: x + x%i = 1 +end subroutine psub