diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/forall_1.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/forall_1.f90 | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/forall_1.f90 b/gcc/testsuite/gfortran.dg/forall_1.f90 new file mode 100644 index 000000000..35fcfdd7f --- /dev/null +++ b/gcc/testsuite/gfortran.dg/forall_1.f90 @@ -0,0 +1,28 @@ +! { dg-do run } +! tests FORALL statements with a mask +dimension i2(15,10), i1(15) +type a + sequence + integer k +end type a +type(a) :: a1(10), a2(5,5) + +i1 = (/ 0, 1, 2, 3, 4, 0, 6, 7, 8, 9, 10, 0, 0, 13, 14 /) +forall (i=1:15, i1(i) /= 0) + i1(i) = 0 +end forall +if (any(i1 /= 0)) call abort + +a1(:)%k = i1(1:10) +forall (i=1:10, a1(i)%k == 0) + a1(i)%k = i +end forall +if (any (a1(:)%k /= (/ (i, i=1,10) /))) call abort + +forall (i=1:15, j=1:10, a1(j)%k <= j) + i2(i,j) = j + i*11 +end forall +do i=1,15 + if (any (i2(i,:) /= (/ (i*11 + j, j=1,10) /))) call abort +end do +end |