Files
clang-p2996/flang/test/Semantics/if_construct02.f90
Tim Keith 99aa87a5b5 [flang][NFC] Simplify semantics test scripts
There were several different ways of handling the option to f18 to
find predefined modules:
- test_errors.sh was created by cmake substituting
  FLANG_INTRINSIC_MODULES_DIR into test_errors.sh.in
- some tests used the flang script which has the option built it
- some tests used %f18_with_includes which was replaced by the path
  to f18 plus the -I option
- some included -I../../include/flang in their run command

To make this more consistent, change %f18 to include the
-intrinsic-module-directory option and use it everywhere, including
to replace %flang and %f18_with_includes. This requires changing all
of the invocations of the test scripts to put %f18 at the end so that
it can expand to more than one argument.

This eliminates the need to generate test_errors.sh which means we
don't need flang/test/Semantics/CMakeLists.txt or the %B substitution.
That makes the test_errors.sh command like the others, replacing
%B/test/Semantics/test_errors.sh with %S/test_errors.sh.

Also remove the OPTIONS: functionality as custom options can be included
in the RUN: command. And remove -I/../../include/flang as that is now
always included.

Differential Revision: https://reviews.llvm.org/D79634
2020-05-11 11:49:25 -07:00

123 lines
2.3 KiB
Fortran

! RUN: %S/test_errors.sh %s %t %f18
! Check that if constructs only accept scalar logical expressions.
! TODO: expand the test to check this restriction for more types.
INTEGER :: I
LOGICAL, DIMENSION (2) :: B
!ERROR: Must be a scalar value, but is a rank-1 array
if ( B ) then
a = 1
end if
!ERROR: Must be a scalar value, but is a rank-1 array
if ( B ) then
a = 2
else
a = 3
endif
!ERROR: Must be a scalar value, but is a rank-1 array
if ( B ) then
a = 4
!ERROR: Must be a scalar value, but is a rank-1 array
else if( B ) then
a = 5
end if
!ERROR: Must be a scalar value, but is a rank-1 array
if ( B ) then
a = 6
!ERROR: Must be a scalar value, but is a rank-1 array
else if( B ) then
a = 7
!ERROR: Must be a scalar value, but is a rank-1 array
elseif( B ) then
a = 8
end if
!ERROR: Must be a scalar value, but is a rank-1 array
if ( B ) then
a = 9
!ERROR: Must be a scalar value, but is a rank-1 array
else if( B ) then
a = 10
else
a = 11
end if
!ERROR: Must be a scalar value, but is a rank-1 array
if ( B ) then
a = 12
!ERROR: Must be a scalar value, but is a rank-1 array
else if( B ) then
a = 13
!ERROR: Must be a scalar value, but is a rank-1 array
else if( B ) then
a = 14
end if
!ERROR: Must have LOGICAL type, but is INTEGER(4)
if ( I ) then
a = 1
end if
!ERROR: Must have LOGICAL type, but is INTEGER(4)
if ( I ) then
a = 2
else
a = 3
endif
!ERROR: Must have LOGICAL type, but is INTEGER(4)
if ( I ) then
a = 4
!ERROR: Must have LOGICAL type, but is INTEGER(4)
else if( I ) then
a = 5
end if
!ERROR: Must have LOGICAL type, but is INTEGER(4)
if ( I ) then
a = 6
!ERROR: Must have LOGICAL type, but is INTEGER(4)
else if( I ) then
a = 7
!ERROR: Must have LOGICAL type, but is INTEGER(4)
elseif( I ) then
a = 8
end if
!ERROR: Must have LOGICAL type, but is INTEGER(4)
if ( I ) then
a = 9
!ERROR: Must have LOGICAL type, but is INTEGER(4)
else if( I ) then
a = 10
else
a = 11
end if
!ERROR: Must have LOGICAL type, but is INTEGER(4)
if ( I ) then
a = 12
!ERROR: Must have LOGICAL type, but is INTEGER(4)
else if( I ) then
a = 13
!ERROR: Must have LOGICAL type, but is INTEGER(4)
else if( I ) then
a = 14
end if
!ERROR: Must have LOGICAL type, but is REAL(4)
if (f()) then
a = 15
end if
contains
real function f()
f = 1.0
end
end