aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/contained_1.f90
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/contained_1.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/contained_1.f9033
1 files changed, 33 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/contained_1.f90 b/gcc/testsuite/gfortran.dg/contained_1.f90
new file mode 100644
index 0000000..9b6e439
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/contained_1.f90
@@ -0,0 +1,33 @@
+! PR15986
+! Siblings may be used as actual arguments, in which case they look like
+! variables during parsing. Also checks that actual variables aren't replaced
+! by siblings with the same name
+! { dg-do run }
+module contained_1_mod
+integer i
+contains
+subroutine a
+ integer :: c = 42
+ call sub(b, c)
+end subroutine a
+subroutine b()
+ i = i + 1
+end subroutine b
+subroutine c
+end subroutine
+end module
+
+subroutine sub (proc, var)
+ external proc1
+ integer var
+
+ if (var .ne. 42) call abort
+ call proc
+end subroutine
+
+program contained_1
+ use contained_1_mod
+ i = 0
+ call a
+ if (i .ne. 1) call abort
+end program