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 29 30 31 32 33 34
|
module submodule_24_mod
implicit none
interface
integer function i()
end function
end interface
interface
module function f(p) result(r)
procedure(i) :: p
integer :: r
end function
end interface
end module
submodule(submodule_24_mod) submodule_24_sub
implicit none
contains
module procedure f
r = p()
end procedure
end submodule
program submodule_24
use submodule_24_mod, only: f
implicit none
if (f(get_four) /= 4) error stop
print *, "ok"
contains
integer function get_four()
get_four = 4
end function
end program
|