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/interface_14.f90 | 73 ++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 gcc/testsuite/gfortran.dg/interface_14.f90 (limited to 'gcc/testsuite/gfortran.dg/interface_14.f90') diff --git a/gcc/testsuite/gfortran.dg/interface_14.f90 b/gcc/testsuite/gfortran.dg/interface_14.f90 new file mode 100644 index 000000000..ea4345b04 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/interface_14.f90 @@ -0,0 +1,73 @@ +! { dg-do compile } +! Checks the fix for a regression PR32526, which was caused by +! the patch for PR31494. The problem here was that the symbol +! 'new' was determined to be ambiguous. +! +! Contributed by Michael Richmond +! + module P_Class + implicit none + private :: init_Personnel + interface new + module procedure init_Personnel + end interface + contains + subroutine init_Personnel(this) + integer, intent (in) :: this + print *, "init personnel", this + end subroutine init_Personnel + end module P_Class + + module S_Class + use P_Class + implicit none + private :: init_Student + type Student + private + integer :: personnel = 1 + end type Student + interface new + module procedure init_Student + end interface + contains + subroutine init_Student(this) + type (Student), intent (in) :: this + call new(this%personnel) + end subroutine init_Student + end module S_Class + + module T_Class + use P_Class + implicit none + private :: init_Teacher + type Teacher + private + integer :: personnel = 2 + end type Teacher + interface new + module procedure init_Teacher + end interface + contains + subroutine init_Teacher(this) + type (Teacher), intent (in) :: this + call new(this%personnel) + end subroutine init_Teacher + end module T_Class + + module poly_Class + use S_Class + use T_Class + end module poly_Class + + module D_Class + use poly_Class + end module D_Class + + use D_Class + type (Teacher) :: a + type (Student) :: b + call new (a) + call new (b) + end + +! { dg-final { cleanup-modules "P_class S_Class T_Class D_Class poly_Class" } } -- cgit v1.2.3