rt_gccstream/gcc/testsuite/gfortran.dg/init_flag_1.f90

58 lines
1.3 KiB
Fortran

! { dg-do run }
! { dg-options "-finit-local-zero -fbackslash" }
program init_flag_1
call real_test
call logical_test
call int_test
call complex_test
call char_test
end program init_flag_1
! Test some initializations for both implicitly and
! explicitly declared local variables.
subroutine real_test
real r1
real r2(10)
dimension r3(10,10)
if (r1 /= 0.0) call abort
if (r2(2) /= 0.0) call abort
if (r3(5,5) /= 0.0) call abort
if (r4 /= 0.0) call abort
end subroutine real_test
subroutine logical_test
logical l1
logical l2(2)
if (l1 .neqv. .false.) call abort
if (l2(2) .neqv. .false.) call abort
end subroutine logical_test
subroutine int_test
integer i1
integer i2(10)
dimension i3(10,10)
if (i1 /= 0) call abort
if (i2(2) /= 0) call abort
if (i3(5,5) /= 0) call abort
if (i4 /= 0) call abort
end subroutine int_test
subroutine complex_test
complex c1
complex c2(20,20)
if (c1 /= (0.0,0.0)) call abort
if (c2(1,1) /= (0.0,0.0)) call abort
end subroutine complex_test
subroutine char_test
character*1 c1
character*8 c2, c3(5)
character c4(10)
if (c1 /= '\0') call abort
if (c2 /= '\0\0\0\0\0\0\0\0') call abort
if (c3(1) /= '\0\0\0\0\0\0\0\0') call abort
if (c3(5) /= '\0\0\0\0\0\0\0\0') call abort
if (c4(5) /= '\0') call abort
end subroutine char_test