diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/associate_8.f03')
-rw-r--r-- | gcc/testsuite/gfortran.dg/associate_8.f03 | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/associate_8.f03 b/gcc/testsuite/gfortran.dg/associate_8.f03 new file mode 100644 index 000000000..a6f9938f0 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/associate_8.f03 @@ -0,0 +1,37 @@ +! { dg-do run } +! { dg-options "-std=f2003 -fall-intrinsics" } + +! PR fortran/38936 +! Check associate to polymorphic entities. + +! Contributed by Tobias Burnus, burnus@gcc.gnu.org. + +type t +end type t + +type, extends(t) :: t2 +end type t2 + +class(t), allocatable :: a, b +allocate( t :: a) +allocate( t2 :: b) + +associate ( one => a, two => b) + select type(two) + type is (t) + call abort () + type is (t2) + print *, 'OK', two + class default + call abort () + end select + select type(one) + type is (t2) + call abort () + type is (t) + print *, 'OK', one + class default + call abort () + end select +end associate +end |