From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; 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. --- gcc/testsuite/gfortran.dg/import.f90 | 78 ++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 gcc/testsuite/gfortran.dg/import.f90 (limited to 'gcc/testsuite/gfortran.dg/import.f90') 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" } } -- cgit v1.2.3