annotate gcc/testsuite/gfortran.dg/coarray_allocate_4.f08 @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ! { dg-do run }
kono
parents:
diff changeset
2 ! { dg-options "-fcoarray=single" }
kono
parents:
diff changeset
3 !
kono
parents:
diff changeset
4 ! Contributed by Gerhard Steinmetz <gerhard.steinmetz.fortran@t-online.de>
kono
parents:
diff changeset
5 ! Andre Vehreschild <vehre@gcc.gnu.org>
kono
parents:
diff changeset
6 ! Check that PR fortran/69451 is fixed.
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 program main
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 implicit none
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 type foo
kono
parents:
diff changeset
13 end type
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 class(foo), allocatable :: p[:]
kono
parents:
diff changeset
16 class(foo), pointer :: r
kono
parents:
diff changeset
17 class(*), allocatable, target :: z
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 allocate(p[*])
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 call s(p, z)
kono
parents:
diff changeset
22 select type (z)
kono
parents:
diff changeset
23 class is (foo)
kono
parents:
diff changeset
24 r => z
kono
parents:
diff changeset
25 class default
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
26 STOP 1
111
kono
parents:
diff changeset
27 end select
kono
parents:
diff changeset
28
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
29 if (.not. associated(r)) STOP 2
111
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 deallocate(r)
kono
parents:
diff changeset
32 deallocate(p)
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 contains
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 subroutine s(x, z)
kono
parents:
diff changeset
37 class(*) :: x[*]
kono
parents:
diff changeset
38 class(*), allocatable:: z
kono
parents:
diff changeset
39 allocate (z, source=x)
kono
parents:
diff changeset
40 end
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 end
kono
parents:
diff changeset
43