summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/import2.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/import2.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/import2.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/import2.f9080
1 files changed, 80 insertions, 0 deletions
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" } }