diff options
author | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
---|---|---|
committer | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
commit | 554fd8c5195424bdbcabf5de30fdc183aba391bd (patch) | |
tree | 976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/gfortran.dg/generic_14.f90 | |
download | cbb-gcc-4.6.4-upstream.tar.bz2 cbb-gcc-4.6.4-upstream.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/generic_14.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/generic_14.f90 | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/generic_14.f90 b/gcc/testsuite/gfortran.dg/generic_14.f90 new file mode 100644 index 000000000..e95f6f2ed --- /dev/null +++ b/gcc/testsuite/gfortran.dg/generic_14.f90 @@ -0,0 +1,105 @@ +! { dg-do compile } +! +! Check whether MODULE PROCEDUREs are properly treated +! They need to be contained in a procedure, i.e. an +! interface in another procedure is invalid; they may, however, +! come from a use-associated procedure. +! (The PROCEDURE statement allows also for non-module procedures +! if there is an explicit interface.) +! +! PR fortran/33228 +! +module inclmod + implicit none + interface + subroutine wrong1(a) + integer :: a + end subroutine wrong1 + end interface + interface gen_incl + module procedure ok1 + end interface gen_incl + external wrong2 + external wrong3 + real wrong3 +contains + subroutine ok1(f) + character :: f + end subroutine ok1 +end module inclmod + +module a + use inclmod + implicit none + interface gen + subroutine ok1_a(a,b) + integer :: a,b + end subroutine ok1_a + module procedure ok1, ok2_a + end interface gen +contains + subroutine ok2_a(a,b,c) + integer :: a,b,c + end subroutine ok2_a +end module a + +module b + use inclmod + interface gen_wrong_0 + module procedure gen_incl ! { dg-error "Cannot change attributes" } + end interface gen_wrong_0 +end module b + +module c + use inclmod + interface gen_wrong_1 + module procedure wrong1 ! { dg-error "is not a module procedure" } + end interface gen_wrong_1 +end module c + +module d + use inclmod + interface gen_wrong_2 + module procedure wrong2 ! { dg-error "Cannot change attributes" } + end interface gen_wrong_2 +end module d + +module e + use inclmod + interface gen_wrong_3 + module procedure wrong3 ! { dg-error "Cannot change attributes" } + end interface gen_wrong_3 +end module e + +module f + implicit none + interface + subroutine wrong_a(a) + integer :: a + end subroutine wrong_a + end interface + interface gen_wrong_4 + module procedure wrong_a ! { dg-error "is not a module procedure" } + end interface gen_wrong_4 +end module f + +module g + implicit none + external wrong_b + interface gen_wrong_5 + module procedure wrong_b ! { dg-error "has no explicit interface" } + end interface gen_wrong_5 +end module g + +module h + implicit none + external wrong_c + real wrong_c + interface gen_wrong_6 + module procedure wrong_c ! { dg-error "has no explicit interface" } + end interface gen_wrong_6 +end module h + +end + +! { dg-final { cleanup-modules "a inclmod" } } |