1 ! Copyright 2019-2022 Free Software Foundation, Inc.
3 ! This program is free software; you can redistribute it and/or modify
4 ! it under the terms of the GNU General Public License as published by
5 ! the Free Software Foundation; either version 3 of the License, or
6 ! (at your option) any later version.
8 ! This program is distributed in the hope that it will be useful,
9 ! but WITHOUT ANY WARRANTY; without even the implied warranty of
10 ! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 ! GNU General Public License for more details.
13 ! You should have received a copy of the GNU General Public License
14 ! along with this program. If not, see <http://www.gnu.org/licenses/> .
20 subroutine print_from_module()
25 program contains_keyword
28 integer :: program_i
, program_j
29 program_j
= 12 ! pre_init
31 program_j
= increment(program_j
) ! pre_increment
32 program_i
= increment_program_global() ! pre_increment_program_global
33 call subroutine_to_call()
34 call step() ! pre_step
35 call hidden_variable()
36 call print_from_module()
37 print '(I2)', program_j
, program_i
! post_init
40 subroutine subroutine_to_call()
43 integer function increment(i
)
46 print *, i
! post_increment
48 integer function increment_program_global()
49 increment_program_global
= program_i
+ 1
50 ! Need to put in a dummy print here to break on as on some systems the
51 ! variables leave scope at "end function", but on others they do not.
52 print *, program_i
! post_increment_global
55 print '(A)', "step" ! post_step
57 subroutine hidden_variable()
60 print *, program_i
! post_hidden
62 end program contains_keyword