1! { dg-do compile }
2! Checks the fix for PR32315, in which the bounds checks below were not being done.
3!
4! Contributed by Tobias Burnus <burnus@gcc.gnu.org>
5!
6program chkdata
7    character(len=20), dimension(4) :: string
8    character(len=20), dimension(0:1,3:4) :: string2
9
10    data (string(i) ,i = 4, 5) /'D', 'E'/ ! { dg-error "above array upper bound" }
11    data (string(i) ,i = 0, 1) /'A', 'B'/ ! { dg-error "below array lower bound" }
12    data (string(i) ,i = 1, 4) /'A', 'B', 'C', 'D'/
13
14    data ((string2(i, j) ,i = 1, 2), j = 3, 4) /'A', 'B', 'C', 'D'/ ! { dg-error "above array upper bound" }
15    data ((string2(i, j) ,i = 0, 1), j = 2, 3) /'A', 'B', 'C', 'D'/ ! { dg-error "below array lower bound" }
16    data ((string2(i, j) ,i = 0, 1), j = 3, 4) /'A', 'B', 'C', 'D'/
17end program chkdata
18