! RUN: %flang_fc1 -fdebug-unparse %s 2>&1 | FileCheck %s
program main
type t
integer, allocatable :: component(:)
end type
type(t) :: x
call init(10)
!CHECK: PRINT *, [INTEGER(4)::int(lbound(x%component,dim=1,kind=8),kind=4)]
print *, lbound(x%component)
!CHECK: PRINT *, [INTEGER(4)::int(size(x%component,dim=1,kind=8)+lbound(x%component,dim=1,kind=8)-1_8,kind=4)]
print *, ubound(x%component)
!CHECK: PRINT *, int(size(x%component,dim=1,kind=8),kind=4)
print *, size(x%component)
!CHECK: PRINT *, 4_8*size(x%component,dim=1,kind=8)
print *, sizeof(x%component)
!CHECK: PRINT *, 1_4
print *, lbound(iota(10), 1)
!CHECK: PRINT *, ubound(iota(10_4),1_4)
print *, ubound(iota(10), 1)
!CHECK: PRINT *, size(iota(10_4))
print *, size(iota(10))
!CHECK: PRINT *, sizeof(iota(10_4))
print *, sizeof(iota(10))
contains
function iota(n) result(result)
integer, intent(in) :: n
integer, allocatable :: result(:)
result = [(j,j=1,n)]
end
subroutine init(n)
integer, intent(in) :: n
allocate(x%component(0:n-1))
end
end