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/import2.f90 | 80 +++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 gcc/testsuite/gfortran.dg/import2.f90 (limited to 'gcc/testsuite/gfortran.dg/import2.f90') diff --git a/gcc/testsuite/gfortran.dg/import2.f90 b/gcc/testsuite/gfortran.dg/import2.f90 new file mode 100644 index 000000000..4a0128a0b --- /dev/null +++ b/gcc/testsuite/gfortran.dg/import2.f90 @@ -0,0 +1,80 @@ +! { dg-do compile } +! { dg-options "-std=f95" } +! { dg-shouldfail "Fortran 2003 feature with -std=f95" } +! Test whether import does not work with -std=f95 +! 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 ! { dg-error "Fortran 2003: IMPORT statement" } + type(modType) :: y ! { dg-error "not been declared within the interface" } + real(kind) :: x ! { dg-error "has not been declared" } + 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 ! { dg-error "Fortran 2003: IMPORT statement" } + type(myType) :: x ! { dg-error "not been declared within the interface" } + integer(dp) :: y ! { dg-error "has not been declared" } + end subroutine bar + subroutine test(x) + import :: myType3 ! { dg-error "Fortran 2003: IMPORT statement" } + import myType3 ! { dg-error "Fortran 2003: IMPORT statement" } + type(myType3) :: x ! { dg-error "not been declared within the interface" } + end subroutine test + end interface + + type(myType) :: y + type(myType3) :: z + integer(dp) :: i8 + y%i = 2 + i8 = 8 + call bar(y,i8) ! { dg-error "Type mismatch in argument" } + if(y%i /= 5 .or. i8/= 42) call abort() + z%i = 7 + call test(z) ! { dg-error "Type mismatch in argument" } + if(z%i /= 1) call abort() +end program foo +! { dg-final { cleanup-modules "testmod" } } -- cgit v1.2.3