From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- .../testsuite/gfortran.dg/proc_ptr_comp_pass_7.f90 | 63 ++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gfortran.dg/proc_ptr_comp_pass_7.f90 (limited to 'gcc-4.9/gcc/testsuite/gfortran.dg/proc_ptr_comp_pass_7.f90') diff --git a/gcc-4.9/gcc/testsuite/gfortran.dg/proc_ptr_comp_pass_7.f90 b/gcc-4.9/gcc/testsuite/gfortran.dg/proc_ptr_comp_pass_7.f90 new file mode 100644 index 000000000..9c960dda2 --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gfortran.dg/proc_ptr_comp_pass_7.f90 @@ -0,0 +1,63 @@ +! { dg-do compile } +! +! PR 46662: [OOP] gfortran accepts "CALL polymorphic%abstract_type%ppc()" +! +! Contributed by Wolfgang Kilian +! cf. http://groups.google.com/group/comp.lang.fortran/browse_thread/thread/a0857fa4a692d518 + +module types + implicit none + + type, abstract :: base_t + integer :: i = 0 + procedure(base_write_i), pointer :: write_procptr + contains + procedure :: write_i => base_write_i + end type base_t + + type, extends (base_t) :: t + end type t + +contains + + subroutine base_write_i (obj) + class (base_t), intent(in) :: obj + print *, obj%i + end subroutine base_write_i + +end module types + + +program main + use types + implicit none + + type(t) :: obj + + print *, "Direct printing" + obj%i = 1 + print *, obj%i + + print *, "Direct printing via parent" + obj%base_t%i = 2 + print *, obj%base_t%i + + print *, "Printing via TBP" + obj%i = 3 + call obj%write_i + + print *, "Printing via parent TBP" + obj%base_t%i = 4 + call obj%base_t%write_i ! { dg-error "is of ABSTRACT type" } + + print *, "Printing via OBP" + obj%i = 5 + obj%write_procptr => base_write_i + call obj%write_procptr + + print *, "Printing via parent OBP" + obj%base_t%i = 6 + obj%base_t%write_procptr => base_write_i + call obj%base_t%write_procptr ! { dg-error "is of ABSTRACT type" } + +end program main -- cgit v1.2.3