summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/class_22.f03
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/class_22.f03')
-rw-r--r--gcc/testsuite/gfortran.dg/class_22.f0331
1 files changed, 31 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/class_22.f03 b/gcc/testsuite/gfortran.dg/class_22.f03
new file mode 100644
index 000000000..df68783b4
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/class_22.f03
@@ -0,0 +1,31 @@
+! { dg-do compile }
+!
+! PR 44212: [OOP] ICE when defining a pointer component before defining the class and calling a TBP then
+!
+! Contributed by Hans-Werner Boschmann <boschmann@tp1.physik.uni-siegen.de>
+
+module ice_module
+
+ type :: B_type
+ class(A_type),pointer :: A_comp
+ end type B_type
+
+ type :: A_type
+ contains
+ procedure :: A_proc
+ end type A_type
+
+contains
+
+ subroutine A_proc(this)
+ class(A_type),target,intent(inout) :: this
+ end subroutine A_proc
+
+ subroutine ice_proc(this)
+ class(A_type) :: this
+ call this%A_proc()
+ end subroutine ice_proc
+
+end module ice_module
+
+! { dg-final { cleanup-modules "ice_module" } }