blob: a0d726adc183b08d077873fb4053d03d4cfb87a6 [file] [log] [blame]
! { dg-do run }
!
! PR fortran/39427
!
! Check constructor functionality.
!
!
module m
interface cons
procedure cons42
end interface cons
contains
integer function cons42()
cons42 = 42
end function cons42
end module m
module m2
type cons
integer :: j = -1
end type cons
interface cons
procedure consT
end interface cons
contains
type(cons) function consT(k)
integer :: k
consT%j = k**2
end function consT
end module m2
use m
use m2, only: cons
implicit none
type(cons) :: x
integer :: k
x = cons(3)
k = cons()
if (x%j /= 9) STOP 1
if (k /= 42) STOP 2
!print *, x%j
!print *, k
end