File: test_call_arg_structinstance_member.f90

package info (click to toggle)
lfortran 0.58.0-4
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 54,512 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 33; javascript: 15
file content (26 lines) | stat: -rw-r--r-- 657 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
module module_test_call_arg_structinstance_member
    implicit none
    type :: data_type
        real(4) :: arr(4)
    end type data_type

contains
    subroutine sub(arr)
        real(4), intent(inout) :: arr(:)
        integer :: i
        do i = 1, 4
            arr(i) = real(i, kind=4) + 10.0_4
        end do
    end subroutine sub
end module module_test_call_arg_structinstance_member

program test_call_arg_structinstance_member
    use module_test_call_arg_structinstance_member
    implicit none
    type(data_type) :: d
    d%arr = 0.0_4
    call sub(d%arr)

    print *, d%arr
    if (any(d%arr /= [11., 12., 13., 14.])) error stop
end program