llvm-project/flang/test/Semantics/canondo17.f90

27 lines
859 B
Fortran

! RUN: %S/test_any.sh %s %flang %t
! Error test -- DO loop uses obsolete loop termination statement
! See R1131 and C1133
! By default, this is not an error and label do are rewritten to non-label do.
! A warning is generated with -Mstandard
! EXEC: ${F18} -funparse-with-symbols -Mstandard %s 2>&1 | ${FileCheck} %s
! CHECK: end do
! The following CHECK-NOT actively uses the fact that the leading zero of labels
! would be removed in the unparse but not the line linked to warnings. We do
! not want to see label do in the unparse only.
! CHECK-NOT: do [1-9]
! CHECK: A DO loop should terminate with an END DO or CONTINUE
subroutine foo9()
real :: a(10, 10), b(10, 10) = 1.0
do 01 k=1,2
forall (i = 1:10, j = 1:10, b(i, j) /= 0.0)
a(i, j) = real (i + j - k)
b(i, j) = a(i, j) + b(i, j) * real (i * j)
01 end forall
end subroutine