annotate gcc/testsuite/gfortran.dg/class_67.f90 @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900 (2020-02-13)
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
1 ! { dg-do run }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
2 !
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
3 ! Test the fix for PR78990 in which the scalarization of the assignment
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
4 ! in the main program failed for two reasons: (i) The conversion of 'v1'
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
5 ! into a class actual was being done after the call to 'return_t1', giving
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
6 ! rise to the ICE reported in comment #1; and (ii) The 'info' descriptor,
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
7 ! required for scalarization was not set, which gave rise to the ICE noted
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
8 ! by the contributor.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
9 !
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
10 ! Contributed by Chris Macmackin <cmacmackin@gmail.com>
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
11 !
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
12 module test_type
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
13 implicit none
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
14
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
15 type t1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
16 integer :: i
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
17 contains
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
18 procedure :: assign
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
19 generic :: assignment(=) => assign
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
20 end type t1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
21
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
22 contains
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
23
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
24 elemental subroutine assign(this,rhs)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
25 class(t1), intent(inout) :: this
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
26 class(t1), intent(in) :: rhs
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
27 this%i = rhs%i
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
28 end subroutine assign
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
29
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
30 function return_t1(arg)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
31 class(t1), dimension(:), intent(in) :: arg
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
32 class(t1), dimension(:), allocatable :: return_t1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
33 allocate(return_t1(size(arg)), source=arg)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
34 end function return_t1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
35
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
36 function return_t1_p(arg)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
37 class(t1), dimension(:), intent(in), target :: arg
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
38 class(t1), dimension(:), pointer :: return_t1_p
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
39 return_t1_p => arg
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
40 end function return_t1_p
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
41 end module test_type
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
42
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
43 program test
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
44 use test_type
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
45 implicit none
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
46
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
47 type(t1), dimension(3) :: v1, v2
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
48 v1%i = [1,2,3]
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
49 v2 = return_t1(v1)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
50 if (any (v2%i .ne. v1%i)) STOP 1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
51
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
52 v1%i = [4,5,6]
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
53 v2 = return_t1_p(v1)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
54 if (any (v2%i .ne. v1%i)) STOP 2
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
55 end program test