summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/array_constructor_16.f90
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/array_constructor_16.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/array_constructor_16.f9034
1 files changed, 34 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/array_constructor_16.f90 b/gcc/testsuite/gfortran.dg/array_constructor_16.f90
new file mode 100644
index 000000000..7c2e8d156
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/array_constructor_16.f90
@@ -0,0 +1,34 @@
+! { dg-do run }
+! Tests the fix for PR31204, in which 'i' below would be incorrectly
+! host associated by the contained subroutines. The checks for 'ii'
+! and 'iii' have been added, since they can be host associated because
+! of the explicit declarations in the main program.
+!
+! Contributed by Joost VandeVondele <jv244@cam.ac.uk>
+!
+ integer ii
+ INTEGER, PARAMETER :: jmin(1:10) = (/ (i, i = 1, 10) /)
+ INTEGER, PARAMETER :: kmin(1:10) = (/ (ii, ii = 1, 10) /)
+ INTEGER, PARAMETER :: lmin(1:10) = (/ (iii, iii = 1, 10) /)
+ integer iii
+ CALL two
+
+CONTAINS
+
+ SUBROUTINE one
+ i = 99
+ ii = 99
+ iii = 999
+ END SUBROUTINE
+
+ SUBROUTINE two
+ i = 0
+ ii = 0
+ iii = 0
+ CALL one
+ IF (i .NE. 0) CALL ABORT ()
+ IF (ii .NE. 99) CALL ABORT ()
+ IF (iii .NE. 999) CALL ABORT ()
+ END SUBROUTINE
+END
+