2 ! PR fortran/66193 - ICE for initialisation of some non-zero-sized arrays
3 ! Testcase by G.Steinmetz
13 integer(8), parameter :: z1(2) = 10 + [ integer(8) :: [ integer(4) ::],1,2]
14 integer(8) :: z2(2) = 10 + [ integer(8) :: [ integer(4) ::],1,2]
16 z3
= 10 + [ integer(8) :: [ integer(4) :: ], 1, 2 ]
17 if ( z1(1) /= 11 .or
. z1(2) /= 12 ) stop 1
18 if ( z2(1) /= 11 .or
. z2(2) /= 12 ) stop 2
19 if ( z3(1) /= 11 .or
. z3(2) /= 12 ) stop 3
23 logical(8), parameter :: z1(3) = .true
. .or
. &
24 [ logical(8) :: [ logical(4) :: ], .false
., .false
., .true
. ]
25 logical(8) :: z2(3) = .true
. .or
. &
26 [ logical(8) :: [ logical(4) :: ], .false
., .false
., .true
. ]
29 [ logical(8) :: [ logical(4) :: ], .false
., .false
., .true
. ]
30 if ( .not
. all(z1
) ) stop 11
31 if ( .not
. all(z2
) ) stop 12
32 if ( .not
. all(z3
) ) stop 13
36 real(8), parameter :: eps
= 4.0_8
* epsilon(1.0_8
)
37 real(8), parameter :: z1(2) = 10. + [ real(8) :: [ real(4) :: ], 1., 2. ]
38 real(8) :: z2(2) = 10. + [ real(8) :: [ real(4) :: ], 1., 2. ]
40 z3
= 10.0 + [ real(8) :: [ real(4) :: ], 1.0, 2.0 ]
42 if ( abs(1-z1(1)/11) > eps
) stop 21
43 if ( abs(1-z1(2)/12) > eps
) stop 22
44 if ( abs(1-z2(1)/11) > eps
) stop 23
45 if ( abs(1-z2(2)/12) > eps
) stop 24
46 if ( abs(1-z3(1)/11) > eps
) stop 25
47 if ( abs(1-z3(2)/12) > eps
) stop 26
51 real, parameter :: x(3) = 2.0 * [real :: 1, (2), 3]
52 real, parameter :: y(2) = [real :: 1, (2)] + 10.0
53 real, parameter :: z(2) = [real ::(1),(2)] + 10.0