2021-02-18 02:53:05 +08:00
|
|
|
! RUN: %flang_fc1 -fsyntax-only -fdebug-pre-fir-tree %s | FileCheck %s
|
2020-01-28 20:58:30 +08:00
|
|
|
|
|
|
|
! Test structure of the Pre-FIR tree
|
|
|
|
|
|
|
|
! CHECK: Subroutine foo
|
|
|
|
subroutine foo()
|
|
|
|
! CHECK: <<DoConstruct>>
|
|
|
|
! CHECK: NonLabelDoStmt
|
|
|
|
do i=1,5
|
|
|
|
! CHECK: PrintStmt
|
|
|
|
print *, "hey"
|
|
|
|
! CHECK: <<DoConstruct>>
|
|
|
|
! CHECK: NonLabelDoStmt
|
|
|
|
do j=1,5
|
|
|
|
! CHECK: PrintStmt
|
|
|
|
print *, "hello", i, j
|
|
|
|
! CHECK: EndDoStmt
|
|
|
|
end do
|
2020-05-23 01:18:26 +08:00
|
|
|
! CHECK: <<End DoConstruct>>
|
2020-01-28 20:58:30 +08:00
|
|
|
! CHECK: EndDoStmt
|
|
|
|
end do
|
2020-05-23 01:18:26 +08:00
|
|
|
! CHECK: <<End DoConstruct>>
|
2020-01-28 20:58:30 +08:00
|
|
|
end subroutine
|
|
|
|
! CHECK: EndSubroutine foo
|
|
|
|
|
|
|
|
! CHECK: BlockData
|
|
|
|
block data
|
|
|
|
integer, parameter :: n = 100
|
|
|
|
integer, dimension(n) :: a, b, c
|
|
|
|
common /arrays/ a, b, c
|
|
|
|
end
|
|
|
|
! CHECK: EndBlockData
|
|
|
|
|
|
|
|
! CHECK: ModuleLike
|
|
|
|
module test_mod
|
|
|
|
interface
|
|
|
|
! check specification parts are not part of the PFT.
|
|
|
|
! CHECK-NOT: node
|
|
|
|
module subroutine dump()
|
|
|
|
end subroutine
|
|
|
|
end interface
|
|
|
|
integer :: xdim
|
|
|
|
real, allocatable :: pressure(:)
|
|
|
|
contains
|
|
|
|
! CHECK: Subroutine foo
|
|
|
|
subroutine foo()
|
|
|
|
contains
|
|
|
|
! CHECK: Subroutine subfoo
|
|
|
|
subroutine subfoo()
|
|
|
|
end subroutine
|
|
|
|
! CHECK: EndSubroutine subfoo
|
|
|
|
! CHECK: Function subfoo2
|
|
|
|
function subfoo2()
|
|
|
|
end function
|
|
|
|
! CHECK: EndFunction subfoo2
|
|
|
|
end subroutine
|
|
|
|
! CHECK: EndSubroutine foo
|
|
|
|
|
|
|
|
! CHECK: Function foo2
|
|
|
|
function foo2(i, j)
|
|
|
|
integer i, j, foo2
|
|
|
|
! CHECK: AssignmentStmt
|
|
|
|
foo2 = i + j
|
|
|
|
contains
|
|
|
|
! CHECK: Subroutine subfoo
|
|
|
|
subroutine subfoo()
|
|
|
|
end subroutine
|
|
|
|
! CHECK: EndSubroutine subfoo
|
|
|
|
end function
|
|
|
|
! CHECK: EndFunction foo2
|
|
|
|
end module
|
|
|
|
! CHECK: EndModuleLike
|
|
|
|
|
|
|
|
! CHECK: ModuleLike
|
|
|
|
submodule (test_mod) test_mod_impl
|
|
|
|
contains
|
|
|
|
! CHECK: Subroutine foo
|
|
|
|
subroutine foo()
|
|
|
|
contains
|
|
|
|
! CHECK: Subroutine subfoo
|
|
|
|
subroutine subfoo()
|
|
|
|
end subroutine
|
|
|
|
! CHECK: EndSubroutine subfoo
|
|
|
|
! CHECK: Function subfoo2
|
|
|
|
function subfoo2()
|
|
|
|
end function
|
|
|
|
! CHECK: EndFunction subfoo2
|
|
|
|
end subroutine
|
|
|
|
! CHECK: EndSubroutine foo
|
|
|
|
! CHECK: MpSubprogram dump
|
|
|
|
module procedure dump
|
|
|
|
! CHECK: FormatStmt
|
|
|
|
11 format (2E16.4, I6)
|
|
|
|
! CHECK: <<IfConstruct>>
|
|
|
|
! CHECK: IfThenStmt
|
|
|
|
if (xdim > 100) then
|
|
|
|
! CHECK: PrintStmt
|
|
|
|
print *, "test: ", xdim
|
|
|
|
! CHECK: ElseStmt
|
|
|
|
else
|
|
|
|
! CHECK: WriteStmt
|
|
|
|
write (*, 11) "test: ", xdim, pressure
|
|
|
|
! CHECK: EndIfStmt
|
|
|
|
end if
|
2020-05-23 01:18:26 +08:00
|
|
|
! CHECK: <<End IfConstruct>>
|
2020-01-28 20:58:30 +08:00
|
|
|
end procedure
|
|
|
|
end submodule
|
|
|
|
! CHECK: EndModuleLike
|
|
|
|
|
|
|
|
! CHECK: BlockData
|
|
|
|
block data named_block
|
|
|
|
integer i, j, k
|
|
|
|
common /indexes/ i, j, k
|
|
|
|
end
|
|
|
|
! CHECK: EndBlockData
|
|
|
|
|
|
|
|
! CHECK: Function bar
|
|
|
|
function bar()
|
|
|
|
end function
|
|
|
|
! CHECK: EndFunction bar
|
|
|
|
|
|
|
|
! CHECK: Program <anonymous>
|
|
|
|
! check specification parts are not part of the PFT.
|
|
|
|
! CHECK-NOT: node
|
|
|
|
use test_mod
|
|
|
|
real, allocatable :: x(:)
|
|
|
|
! CHECK: AllocateStmt
|
|
|
|
allocate(x(foo2(10, 30)))
|
|
|
|
end
|
|
|
|
! CHECK: EndProgram
|