aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f03
diff options
context:
space:
mode:
authorBen Cheng <bccheng@google.com>2014-03-25 22:37:19 -0700
committerBen Cheng <bccheng@google.com>2014-03-25 22:37:19 -0700
commit1bc5aee63eb72b341f506ad058502cd0361f0d10 (patch)
treec607e8252f3405424ff15bc2d00aa38dadbb2518 /gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f03
parent283a0bf58fcf333c58a2a92c3ebbc41fb9eb1fdb (diff)
downloadtoolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.gz
toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.bz2
toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.zip
Initial checkin of GCC 4.9.0 from trunk (r208799).
Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba
Diffstat (limited to 'gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f03')
-rw-r--r--gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f0352
1 files changed, 52 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f03 b/gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f03
new file mode 100644
index 000000000..5116c661b
--- /dev/null
+++ b/gcc-4.9/gcc/testsuite/gfortran.dg/class_14.f03
@@ -0,0 +1,52 @@
+! { dg-do compile }
+! Test the final fix for PR42353, in which a compilation error was
+! occurring because the derived type of the initializer of the vtab
+! component '$extends' was not the same as that of the component.
+!
+! Contributed by Harald Anlauf <anlauf@gmx.de>
+!
+module abstract_vector
+ implicit none
+
+ type, abstract :: vector_class
+ end type vector_class
+end module abstract_vector
+!-------------------------
+module concrete_vector
+ use abstract_vector
+ implicit none
+
+ type, extends(vector_class) :: trivial_vector_type
+ end type trivial_vector_type
+
+ private :: my_assign
+contains
+ subroutine my_assign (this,v)
+ class(trivial_vector_type), intent(inout) :: this
+ class(vector_class), intent(in) :: v
+ end subroutine my_assign
+end module concrete_vector
+!---------------------------
+module concrete_gradient
+ use abstract_vector
+ implicit none
+
+ type, abstract, extends(vector_class) :: gradient_class
+ end type gradient_class
+
+ type, extends(gradient_class) :: trivial_gradient_type
+ end type trivial_gradient_type
+
+ private :: my_assign
+contains
+ subroutine my_assign (this,v)
+ class(trivial_gradient_type), intent(inout) :: this
+ class(vector_class), intent(in) :: v
+ end subroutine my_assign
+end module concrete_gradient
+!----------------------------
+module concrete_inner_product
+ use concrete_vector
+ use concrete_gradient
+ implicit none
+end module concrete_inner_product