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 --- .../gcc/testsuite/gfortran.dg/select_type_10.f03 | 32 ++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gfortran.dg/select_type_10.f03 (limited to 'gcc-4.9/gcc/testsuite/gfortran.dg/select_type_10.f03') diff --git a/gcc-4.9/gcc/testsuite/gfortran.dg/select_type_10.f03 b/gcc-4.9/gcc/testsuite/gfortran.dg/select_type_10.f03 new file mode 100644 index 000000000..0db9af959 --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gfortran.dg/select_type_10.f03 @@ -0,0 +1,32 @@ +! { dg-do compile } +! +! PR 42167: [OOP] SELECT TYPE with function return value +! +! Contributed by Damian Rouson + +module bar_module + + implicit none + type :: bar + real ,dimension(:) ,allocatable :: f + contains + procedure :: total + end type + +contains + + function total(lhs,rhs) + class(bar) ,intent(in) :: lhs + class(bar) ,intent(in) :: rhs + class(bar) ,pointer :: total + select type(rhs) + type is (bar) + allocate(bar :: total) + select type(total) + type is (bar) + total%f = lhs%f + rhs%f + end select + end select + end function + +end module -- cgit v1.2.3