summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/used_types_10.f90
diff options
context:
space:
mode:
authorupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
committerupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
commit554fd8c5195424bdbcabf5de30fdc183aba391bd (patch)
tree976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/gfortran.dg/used_types_10.f90
downloadcbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.bz2
cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.xz
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository.
Diffstat (limited to 'gcc/testsuite/gfortran.dg/used_types_10.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/used_types_10.f9072
1 files changed, 72 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/used_types_10.f90 b/gcc/testsuite/gfortran.dg/used_types_10.f90
new file mode 100644
index 000000000..c35fb58e6
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/used_types_10.f90
@@ -0,0 +1,72 @@
+! { dg-do compile }
+! Tests the fix for PR28959 in which interface derived types were
+! not always being associated.
+!
+! Contributed by Salvatore Filippone <sfilippone@uniroma2.it>
+!
+module derived_type_mod
+
+ type foo_dtype
+ integer, pointer :: v1(:)=>null()
+ end type foo_dtype
+
+
+end module derived_type_mod
+
+
+Module tools
+
+ interface foo_d_sub
+ subroutine cdalv(m, v, i, desc_a, info, flag)
+ use derived_type_mod
+ Integer, intent(in) :: m,i, v(:)
+ integer, intent(in), optional :: flag
+ integer, intent(out) :: info
+ Type(foo_dtype), intent(out) :: desc_a
+ end subroutine cdalv
+ end interface
+
+end module tools
+
+
+
+subroutine foo_bar(a,p,info)
+ use derived_type_mod
+ implicit none
+
+ type(foo_dtype), intent(in) :: a
+ type(foo_dtype), intent(inout) :: p
+ integer, intent(out) :: info
+
+ info=0
+
+ call inner_sub(info)
+
+
+ return
+
+
+contains
+
+ subroutine inner_sub(info)
+ use tools
+ implicit none
+
+ integer, intent(out) :: info
+
+ integer :: i, nt,iv(10)
+
+ i = 0
+ nt = 1
+
+ call foo_d_sub(nt,iv,i,p,info,flag=1)
+
+ return
+
+
+ end subroutine inner_sub
+
+
+
+end subroutine foo_bar
+! { dg-final { cleanup-modules "derived_type_mod tools" } }