! RUN: %python %S/test_errors.py %s %flang_fc1 -pedantic -Werror
! Tests the checking of storage sequence argument association (F'2023 15.2.5.12)
module nonchar
contains
subroutine scalar(a)
real a
end
subroutine explicit1(a)
real a(2)
end
subroutine explicit2(a)
real a(2,2)
end
subroutine assumedSize1(a)
real a(*)
end
subroutine assumedSize2(a)
real a(2,*)
end
subroutine assumedShape1(a)
real a(:)
end
subroutine assumedShape2(a)
real a(:,:)
end
subroutine assumedRank(a)
real a(..)
end
subroutine allocatable0(a)
real, allocatable :: a
end
subroutine allocatable1(a)
real, allocatable :: a(:)
end
subroutine allocatable2(a)
real, allocatable :: a(:,:)
end
subroutine pointer0(a)
real, intent(in), pointer :: a
end
subroutine pointer1(a)
real, intent(in), pointer :: a(:)
end
subroutine pointer2(a)
real, intent(in), pointer :: a(:,:)
end
subroutine coarray0(a)
real a[*]
end
subroutine test
real, target :: scalar0
real, target :: vector1(1), vector2(2), vector4(4)
real, target :: matrix11(1,1), matrix12(1,2), matrix22(2,2)
real, allocatable :: alloScalar, alloVector(:), alloMatrix(:,:)
call scalar(scalar0)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
call scalar(vector1)
call scalar(vector1(1))
!ERROR: Whole scalar actual argument may not be associated with a dummy argument 'a=' array
call explicit1(scalar0)
!ERROR: Actual argument array has fewer elements (1) than dummy argument 'a=' array (2)
call explicit1(vector1)
call explicit1(vector2)
call explicit1(vector4)
!ERROR: Actual argument has fewer elements remaining in storage sequence (1) than dummy argument 'a=' array (2)
call explicit1(vector2(2))
call explicit1(vector4(3))
!ERROR: Actual argument has fewer elements remaining in storage sequence (1) than dummy argument 'a=' array (2)
call explicit1(vector4(4))
!ERROR: Actual argument array has fewer elements (1) than dummy argument 'a=' array (2)
call explicit1(matrix11)
!ERROR: Whole scalar actual argument may not be associated with a dummy argument 'a=' array
call explicit2(scalar0)
!ERROR: Actual argument array has fewer elements (1) than dummy argument 'a=' array (4)
call explicit2(vector1)
!ERROR: Actual argument array has fewer elements (2) than dummy argument 'a=' array (4)
call explicit2(vector2)
call explicit2(vector4)
!ERROR: Actual argument has fewer elements remaining in storage sequence (1) than dummy argument 'a=' array (4)
call explicit2(vector2(2))
!ERROR: Actual argument has fewer elements remaining in storage sequence (3) than dummy argument 'a=' array (4)
call explicit2(vector4(2))
call explicit2(vector4(1))
!ERROR: Actual argument array has fewer elements (1) than dummy argument 'a=' array (4)
call explicit2(matrix11)
!ERROR: Actual argument array has fewer elements (2) than dummy argument 'a=' array (4)
call explicit2(matrix12)
call explicit2(matrix22)
call explicit2(matrix22(1,1))
!ERROR: Actual argument has fewer elements remaining in storage sequence (3) than dummy argument 'a=' array (4)
call explicit2(matrix22(2,1))
!ERROR: Whole scalar actual argument may not be associated with a dummy argument 'a=' array
call assumedSize1(scalar0)
call assumedSize1(vector1)
call assumedSize1(vector2)
call assumedSize1(vector4)
call assumedSize1(vector2(2))
call assumedSize1(vector4(2))
call assumedSize1(vector4(1))
call assumedSize1(matrix11)
call assumedSize1(matrix12)
call assumedSize1(matrix22)
call assumedSize1(matrix22(1,1))
call assumedSize1(matrix22(2,1))
!ERROR: Whole scalar actual argument may not be associated with a dummy argument 'a=' array
call assumedSize2(scalar0)
call assumedSize2(vector1)
call assumedSize2(vector2)
call assumedSize2(vector4)
call assumedSize2(vector2(2))
call assumedSize2(vector4(2))
call assumedSize2(vector4(1))
call assumedSize2(matrix11)
call assumedSize2(matrix12)
call assumedSize2(matrix22)
call assumedSize2(matrix22(1,1))
call assumedSize2(matrix22(2,1))
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape1(scalar0)
call assumedShape1(vector1)
call assumedShape1(vector2)
call assumedShape1(vector4)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape1(vector2(2))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call assumedShape1(matrix11)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call assumedShape1(matrix12)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call assumedShape1(matrix22)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape1(matrix22(1,1))
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape2(scalar0)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call assumedShape2(vector1)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call assumedShape2(vector2)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call assumedShape2(vector4)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape2(vector2(2))
call assumedShape2(matrix11)
call assumedShape2(matrix12)
call assumedShape2(matrix22)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape2(matrix22(1,1))
call assumedRank(scalar0)
call assumedRank(vector1)
call assumedRank(vector1(1))
call assumedRank(matrix11)
call assumedRank(matrix11(1,1))
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable0(scalar0)
call allocatable0(alloScalar)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
call allocatable0(alloVector)
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable0(alloVector(1))
!ERROR: Rank of dummy argument is 0, but actual argument has rank 2
call allocatable0(alloMatrix)
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable0(alloMatrix(1,1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable1(scalar0)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
call allocatable1(alloScalar)
call allocatable1(alloVector)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable1(alloVector(1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call allocatable1(alloMatrix)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable1(alloMatrix(1,1))
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable2(scalar0)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
call allocatable2(alloScalar)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call allocatable2(alloVector)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable2(alloVector(1))
call allocatable2(alloMatrix)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable2(alloMatrix(1,1))
call pointer0(scalar0)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
!ERROR: Pointer has rank 0 but target has rank 1
call pointer0(vector1)
call pointer0(vector1(1))
!ERROR: Rank of dummy argument is 0, but actual argument has rank 2
!ERROR: Pointer has rank 0 but target has rank 2
call pointer0(matrix11)
call pointer0(matrix11(1,1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: Pointer has rank 1 but target has rank 0
call pointer1(scalar0)
call pointer1(vector1)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: Pointer has rank 1 but target has rank 0
call pointer1(vector1(1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
!ERROR: Pointer has rank 1 but target has rank 2
call pointer1(matrix11)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: Pointer has rank 1 but target has rank 0
call pointer1(matrix11(1,1))
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: Pointer has rank 2 but target has rank 0
call pointer2(scalar0)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
!ERROR: Pointer has rank 2 but target has rank 1
call pointer2(vector1)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: Pointer has rank 2 but target has rank 0
call pointer2(vector1(1))
call pointer2(matrix11)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: Pointer has rank 2 but target has rank 0
call pointer2(matrix11(1,1))
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(scalar0)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(vector1)
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(vector1(1))
!ERROR: Rank of dummy argument is 0, but actual argument has rank 2
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(matrix11)
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(matrix11(1,1))
end
end
module char
contains
subroutine scalar(a)
character(2) a
end
subroutine explicit1(a)
character(2) a(2)
end
subroutine explicit2(a)
character(2) a(2,2)
end
subroutine assumedSize1(a)
character(2) a(*)
end
subroutine assumedSize2(a)
character(2) a(2,*)
end
subroutine assumedShape1(a)
character(2) a(:)
end
subroutine assumedShape2(a)
character(2) a(:,:)
end
subroutine assumedRank(a)
character(2) a(..)
end
subroutine allocatable0(a)
character(2), allocatable :: a
end
subroutine allocatable1(a)
character(2), allocatable :: a(:)
end
subroutine allocatable2(a)
character(2), allocatable :: a(:,:)
end
subroutine pointer0(a)
character(2), intent(in), pointer :: a
end
subroutine pointer1(a)
character(2), intent(in), pointer :: a(:)
end
subroutine pointer2(a)
character(2), intent(in), pointer :: a(:,:)
end
subroutine coarray0(a)
character(2) a[*]
end
subroutine test
character(2), target :: scalar0
character(2), target :: vector1(1), vector2(2), vector4(4)
character(2), target :: matrix11(1,1), matrix12(1,2), matrix22(2,2)
character(2), allocatable :: alloScalar, alloVector(:), alloMatrix(:,:)
call scalar(scalar0)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
call scalar(vector1)
call scalar(vector1(1))
!ERROR: Actual argument has fewer characters remaining in storage sequence (2) than dummy argument 'a=' (4)
call explicit1(scalar0)
!ERROR: Actual argument array has fewer characters (2) than dummy argument 'a=' array (4)
call explicit1(vector1)
call explicit1(vector2)
call explicit1(vector4)
!ERROR: Actual argument has fewer characters remaining in storage sequence (2) than dummy argument 'a=' (4)
call explicit1(vector2(2))
!ERROR: Actual argument has fewer characters remaining in storage sequence (3) than dummy argument 'a=' (4)
call explicit1(vector2(1)(2:2))
call explicit1(vector4(3))
!ERROR: Actual argument has fewer characters remaining in storage sequence (2) than dummy argument 'a=' (4)
call explicit1(vector4(4))
!ERROR: Actual argument array has fewer characters (2) than dummy argument 'a=' array (4)
call explicit1(matrix11)
call explicit1(matrix12)
call explicit1(matrix12(1,1))
!ERROR: Actual argument has fewer characters remaining in storage sequence (3) than dummy argument 'a=' (4)
call explicit1(matrix12(1,1)(2:2))
!ERROR: Actual argument has fewer characters remaining in storage sequence (2) than dummy argument 'a=' (4)
call explicit1(matrix12(1,2))
!ERROR: Actual argument has fewer characters remaining in storage sequence (2) than dummy argument 'a=' (8)
call explicit2(scalar0)
!ERROR: Actual argument array has fewer characters (2) than dummy argument 'a=' array (8)
call explicit2(vector1)
!ERROR: Actual argument array has fewer characters (4) than dummy argument 'a=' array (8)
call explicit2(vector2)
call explicit2(vector4)
!ERROR: Actual argument has fewer characters remaining in storage sequence (2) than dummy argument 'a=' (8)
call explicit2(vector2(2))
!ERROR: Actual argument has fewer characters remaining in storage sequence (6) than dummy argument 'a=' (8)
call explicit2(vector4(2))
call explicit2(vector4(1))
!ERROR: Actual argument array has fewer characters (2) than dummy argument 'a=' array (8)
call explicit2(matrix11)
!ERROR: Actual argument array has fewer characters (4) than dummy argument 'a=' array (8)
call explicit2(matrix12)
call explicit2(matrix22)
call explicit2(matrix22(1,1))
!ERROR: Actual argument has fewer characters remaining in storage sequence (7) than dummy argument 'a=' (8)
call explicit2(matrix22(1,1)(2:2))
!ERROR: Actual argument has fewer characters remaining in storage sequence (6) than dummy argument 'a=' (8)
call explicit2(matrix22(2,1))
call assumedSize1(scalar0)
call assumedSize1(vector1)
call assumedSize1(vector2)
call assumedSize1(vector4)
call assumedSize1(vector2(2))
call assumedSize1(vector4(2))
call assumedSize1(vector4(1))
call assumedSize1(matrix11)
call assumedSize1(matrix12)
call assumedSize1(matrix22)
call assumedSize1(matrix22(1,1))
call assumedSize1(matrix22(2,1))
call assumedSize2(scalar0)
call assumedSize2(vector1)
call assumedSize2(vector2)
call assumedSize2(vector4)
call assumedSize2(vector2(2))
call assumedSize2(vector4(2))
call assumedSize2(vector4(1))
call assumedSize2(matrix11)
call assumedSize2(matrix12)
call assumedSize2(matrix22)
call assumedSize2(matrix22(1,1))
call assumedSize2(matrix22(2,1))
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape1(scalar0)
call assumedShape1(vector1)
call assumedShape1(vector2)
call assumedShape1(vector4)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape1(vector2(2))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call assumedShape1(matrix11)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call assumedShape1(matrix12)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call assumedShape1(matrix22)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape1(matrix22(1,1))
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape2(scalar0)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call assumedShape2(vector1)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call assumedShape2(vector2)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call assumedShape2(vector4)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape2(vector2(2))
call assumedShape2(matrix11)
call assumedShape2(matrix12)
call assumedShape2(matrix22)
!ERROR: Scalar actual argument may not be associated with assumed-shape dummy argument 'a='
call assumedShape2(matrix22(1,1))
call assumedRank(scalar0)
call assumedRank(vector1)
call assumedRank(vector1(1))
call assumedRank(matrix11)
call assumedRank(matrix11(1,1))
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable0(scalar0)
call allocatable0(alloScalar)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
call allocatable0(alloVector)
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable0(alloVector(1))
!ERROR: Rank of dummy argument is 0, but actual argument has rank 2
call allocatable0(alloMatrix)
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable0(alloMatrix(1,1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable1(scalar0)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
call allocatable1(alloScalar)
call allocatable1(alloVector)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable1(alloVector(1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
call allocatable1(alloMatrix)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable1(alloMatrix(1,1))
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable2(scalar0)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
call allocatable2(alloScalar)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
call allocatable2(alloVector)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable2(alloVector(1))
call allocatable2(alloMatrix)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: ALLOCATABLE dummy argument 'a=' must be associated with an ALLOCATABLE actual argument
call allocatable2(alloMatrix(1,1))
call pointer0(scalar0)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
!ERROR: Pointer has rank 0 but target has rank 1
call pointer0(vector1)
call pointer0(vector1(1))
!ERROR: Rank of dummy argument is 0, but actual argument has rank 2
!ERROR: Pointer has rank 0 but target has rank 2
call pointer0(matrix11)
call pointer0(matrix11(1,1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: Pointer has rank 1 but target has rank 0
call pointer1(scalar0)
call pointer1(vector1)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: Pointer has rank 1 but target has rank 0
call pointer1(vector1(1))
!ERROR: Rank of dummy argument is 1, but actual argument has rank 2
!ERROR: Pointer has rank 1 but target has rank 2
call pointer1(matrix11)
!ERROR: Rank of dummy argument is 1, but actual argument has rank 0
!ERROR: Pointer has rank 1 but target has rank 0
call pointer1(matrix11(1,1))
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: Pointer has rank 2 but target has rank 0
call pointer2(scalar0)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 1
!ERROR: Pointer has rank 2 but target has rank 1
call pointer2(vector1)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: Pointer has rank 2 but target has rank 0
call pointer2(vector1(1))
call pointer2(matrix11)
!ERROR: Rank of dummy argument is 2, but actual argument has rank 0
!ERROR: Pointer has rank 2 but target has rank 0
call pointer2(matrix11(1,1))
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(scalar0)
!ERROR: Rank of dummy argument is 0, but actual argument has rank 1
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(vector1)
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(vector1(1))
!ERROR: Rank of dummy argument is 0, but actual argument has rank 2
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(matrix11)
!ERROR: Actual argument associated with coarray dummy argument 'a=' must be a coarray
call coarray0(matrix11(1,1))
!WARNING: Actual argument variable length '1' is less than expected length '2'
call scalar(scalar0(1:1))
!WARNING: Actual argument expression length '1' is less than expected length '2'
call scalar('a')
end
end