From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- .../gcc/testsuite/gfortran.dg/array_section_1.f90 | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gfortran.dg/array_section_1.f90 (limited to 'gcc-4.9/gcc/testsuite/gfortran.dg/array_section_1.f90') diff --git a/gcc-4.9/gcc/testsuite/gfortran.dg/array_section_1.f90 b/gcc-4.9/gcc/testsuite/gfortran.dg/array_section_1.f90 new file mode 100644 index 000000000..4d5eedf2a --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gfortran.dg/array_section_1.f90 @@ -0,0 +1,39 @@ +! { dg-do run } +! { dg-options "-fbounds-check" } +! Tests the fix for PR30003, in which the 'end' of an array section +! would not be evaluated at all if it was on the lhs of an assignment +! or would be evaluated many times if bound checking were on. +! +! Contributed by Erik Edelmann +! + implicit none + integer :: a(5), b(3), cnt + + b = [ 1, 2, 3 ] +! Check the lhs references + cnt = 0 + a(bar(1):3) = b + if (cnt /= 1) call abort () + cnt = 0 + a(1:bar(3)) = b + if (cnt /= 1) call abort () + cnt = 0 + a(1:3:bar(1)) = b + if (cnt /= 1) call abort () +! Check the rhs references + cnt = 0 + a(1:3) = b(bar(1):3) + if (cnt /= 1) call abort () + cnt = 0 + a(1:3) = b(1:bar(3)) + if (cnt /= 1) call abort () + cnt = 0 + a(1:3) = b(1:3:bar(1)) + if (cnt /= 1) call abort () +contains + integer function bar(n) + integer, intent(in) :: n + cnt = cnt + 1 + bar = n + end function bar +end -- cgit v1.2.3