diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/class_22.f03')
-rw-r--r-- | gcc/testsuite/gfortran.dg/class_22.f03 | 31 |
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" } } |