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
123 lines
2.3 KiB
Fortran
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
|