File: global_array_pointer_01.f90

package info (click to toggle)
lfortran 0.58.0-3
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 54,508 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 34; javascript: 15
file content (28 lines) | stat: -rw-r--r-- 724 bytes parent folder | download | duplicates (4)
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
27
28
module global_array_pointer_01_mod
    implicit none
    integer, dimension(:), pointer :: ptr_in
    integer, target :: i(1)
    contains 
    subroutine sub_arr_pointer1
        ptr_in => i
        i = [343]
        print *, ptr_in(1)
        print *, i(1)
        if(ptr_in(1) /= 343) error stop 
    end subroutine sub_arr_pointer1

    subroutine sub_arr_pointer2
        ptr_in(1) = 0
        print *, ptr_in(1)
        print *, i(1)
        if(i(1) /= 0) error stop
    end subroutine sub_arr_pointer2
end module global_array_pointer_01_mod

program global_array_pointer_01
    use global_array_pointer_01_mod
    implicit none
    call sub_arr_pointer1
    call sub_arr_pointer2
end program global_array_pointer_01