forall_3.f90   [plain text]


! the problem here was that we had forgot to call
! fold_convert in gfc_trans_pointer_assign_need_temp
! so that we got a pointer to char instead of a 
! pointer to an array
! we really don't need a temp here.
! { dg-do compile }

      program test_forall
         type element
            character(32), pointer :: name
         end type element
         type(element)     :: charts(50)
         character(32), target :: names(50)
         forall(i=1:50)
            charts(i)%name => names(i)
         end forall
      end