http://gcc.gnu.org/bugzilla/show_bug.cgi?id=49802

--- Comment #2 from Tobias Burnus <burnus at gcc dot gnu.org> 2011-07-21 
09:55:16 UTC ---
Created attachment 24803
  --> http://gcc.gnu.org/bugzilla/attachment.cgi?id=24803
Patch for the resolver/parse part - not for the actual implementation

Implementation strategy:

* For scalar types, continue to pass by value (for optimization purpose)

* For strings, arrays, and complicated DT: Copy the data and pass by reference.

* For VALUE + OPTIONAL - also for scalars: copy and pass by reference

Note: For generating a copy one needs - as already currently - do a deep copy
to capture also the allocatable components.

Example for alloc components with VALUE. The example fails (wrong result) with
NAG, ifort, gfortran and g95; pgi gets an ICE and crayftn states "The array
syntax statement is not conformable", which also looks bogus.

I believe that the test case is valid Fortran 2003.

implicit none
type t
  integer, allocatable :: A(:)
end type t

integer :: i
type(t) :: x

allocate(x%A(8))
x%A = [(i, i = 1, 8)]

call by_value(x)
print *, x%A

if (any (x%A /= [(i, i = 1, 8)])) call abort()

contains
  subroutine by_value(y)
    type(t), value :: y
    y%A = [(-10*i, i=1,9)]
    print *, y%A
  end subroutine
end

Reply via email to