summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/use_13.f90
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/use_13.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/use_13.f9045
1 files changed, 45 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/use_13.f90 b/gcc/testsuite/gfortran.dg/use_13.f90
new file mode 100644
index 000000000..1fe7b1eac
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/use_13.f90
@@ -0,0 +1,45 @@
+! { dg-do run }
+!
+! PR fortran/44360
+!
+! Test-case based on a contribution of Vittorio Zecca.
+!
+! The used subroutine was not the use-associated but the host associated one!
+! The use-associated function/variable were already working properly.
+!
+module m
+ integer :: var = 43
+contains
+ integer function fun()
+ fun = 42
+ end function fun
+ subroutine fun2()
+ var = 44
+ end subroutine fun2
+end module m
+
+module m2
+ integer :: var = -2
+contains
+ subroutine test()
+ ! All procedures/variables below refer to the ones in module "m"
+ ! and not to the siblings in this module "m2".
+ use m
+ if (fun() /= 42) call abort()
+ if (var /= 43) call abort()
+ call fun2()
+ if (var /= 44) call abort()
+ end subroutine test
+ integer function fun()
+ call abort()
+ fun = -3
+ end function fun
+ subroutine fun2()
+ call abort()
+ end subroutine fun2
+end module m2
+
+use m2
+call test()
+end
+! { dg-final { cleanup-modules "m m2" } }