summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/import.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/import.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/import.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/import.f9078
1 files changed, 78 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/import.f90 b/gcc/testsuite/gfortran.dg/import.f90
new file mode 100644
index 000000000..521f87222
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/import.f90
@@ -0,0 +1,78 @@
+! { dg-do run }
+! Test whether import works
+! PR fortran/29601
+
+subroutine test(x)
+ type myType3
+ sequence
+ integer :: i
+ end type myType3
+ type(myType3) :: x
+ if(x%i /= 7) call abort()
+ x%i = 1
+end subroutine test
+
+
+subroutine bar(x,y)
+ type myType
+ sequence
+ integer :: i
+ end type myType
+ type(myType) :: x
+ integer(8) :: y
+ if(y /= 8) call abort()
+ if(x%i /= 2) call abort()
+ x%i = 5
+ y = 42
+end subroutine bar
+
+module testmod
+ implicit none
+ integer, parameter :: kind = 8
+ type modType
+ real :: rv
+ end type modType
+ interface
+ subroutine other(x,y)
+ import
+ real(kind) :: x
+ type(modType) :: y
+ end subroutine
+ end interface
+end module testmod
+
+program foo
+ integer, parameter :: dp = 8
+ type myType
+ sequence
+ integer :: i
+ end type myType
+ type myType3
+ sequence
+ integer :: i
+ end type myType3
+ interface
+ subroutine bar(x,y)
+ import
+ type(myType) :: x
+ integer(dp) :: y
+ end subroutine bar
+ subroutine test(x)
+ import :: myType3
+ import myType3 ! { dg-warning "already IMPORTed from" }
+ type(myType3) :: x
+ end subroutine test
+ end interface
+
+ type(myType) :: y
+ type(myType3) :: z
+ integer(8) :: i8
+ y%i = 2
+ i8 = 8
+ call bar(y,i8)
+ if(y%i /= 5 .or. i8/= 42) call abort()
+ z%i = 7
+ call test(z)
+ if(z%i /= 1) call abort()
+end program foo
+! { dg-final { cleanup-modules "testmod" } }