2020-02-14 22:02:29 +08:00
|
|
|
! RUN: %S/test_modfile.sh %s %f18 %t
|
2018-07-17 07:24:14 +08:00
|
|
|
! Check correct modfile generation for type with private component.
|
|
|
|
module m
|
|
|
|
integer :: i
|
|
|
|
integer, private :: j
|
|
|
|
type :: t
|
|
|
|
integer :: i
|
|
|
|
integer, private :: j
|
|
|
|
end type
|
|
|
|
type, private :: u
|
|
|
|
end type
|
|
|
|
type(t) :: x
|
|
|
|
end
|
|
|
|
|
|
|
|
!Expect: m.mod
|
|
|
|
!module m
|
2018-09-12 08:33:42 +08:00
|
|
|
!integer(4)::i
|
|
|
|
!integer(4),private::j
|
2018-07-17 07:24:14 +08:00
|
|
|
!type::t
|
2018-09-12 08:33:42 +08:00
|
|
|
!integer(4)::i
|
|
|
|
!integer(4),private::j
|
2018-07-17 07:24:14 +08:00
|
|
|
!end type
|
2018-09-08 06:39:20 +08:00
|
|
|
!type,private::u
|
|
|
|
!end type
|
2018-07-17 07:24:14 +08:00
|
|
|
!type(t)::x
|
|
|
|
!end
|
2019-06-25 03:35:17 +08:00
|
|
|
|
|
|
|
! Check correct modfile generation for type with private module procedure.
|
|
|
|
|
|
|
|
module m2
|
|
|
|
private :: s1
|
|
|
|
contains
|
|
|
|
subroutine s1()
|
|
|
|
end
|
|
|
|
subroutine s2()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
!Expect: m2.mod
|
|
|
|
!module m2
|
|
|
|
! private::s1
|
|
|
|
!contains
|
|
|
|
! subroutine s1()
|
|
|
|
! end
|
|
|
|
! subroutine s2()
|
|
|
|
! end
|
|
|
|
!end
|
|
|
|
|
|
|
|
module m3
|
|
|
|
private
|
|
|
|
public :: f1
|
|
|
|
contains
|
|
|
|
real function f1()
|
|
|
|
end
|
|
|
|
real function f2()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
!Expect: m3.mod
|
|
|
|
!module m3
|
|
|
|
! private::f2
|
|
|
|
!contains
|
|
|
|
! function f1()
|
|
|
|
! real(4)::f1
|
|
|
|
! end
|
|
|
|
! function f2()
|
|
|
|
! real(4)::f2
|
|
|
|
! end
|
|
|
|
!end
|
2019-08-21 05:49:37 +08:00
|
|
|
|
|
|
|
! Test optional dummy procedure
|
|
|
|
module m4
|
|
|
|
contains
|
|
|
|
subroutine s(f)
|
|
|
|
interface
|
|
|
|
logical recursive function f()
|
|
|
|
implicit none
|
|
|
|
end function
|
|
|
|
end interface
|
|
|
|
optional f
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
!Expect: m4.mod
|
|
|
|
!module m4
|
|
|
|
!contains
|
|
|
|
! subroutine s(f)
|
|
|
|
! optional::f
|
|
|
|
! interface
|
|
|
|
! recursive function f()
|
|
|
|
! logical(4)::f
|
|
|
|
! end
|
|
|
|
! end interface
|
|
|
|
! end
|
|
|
|
!end
|