annotate gcc/testsuite/gfortran.dg/protected_8.f90 @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ! { dg-do compile }
kono
parents:
diff changeset
2 !
kono
parents:
diff changeset
3 ! PR fortran/46122
kono
parents:
diff changeset
4 !
kono
parents:
diff changeset
5 ! PROTECT check
kono
parents:
diff changeset
6 !
kono
parents:
diff changeset
7 ! Contributed by Jared Ahern
kono
parents:
diff changeset
8 !
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 MODULE amod
kono
parents:
diff changeset
11 IMPLICIT NONE
kono
parents:
diff changeset
12 TYPE foo
kono
parents:
diff changeset
13 INTEGER :: i = 4
kono
parents:
diff changeset
14 INTEGER, POINTER :: j => NULL()
kono
parents:
diff changeset
15 END TYPE foo
kono
parents:
diff changeset
16 TYPE(foo), SAVE, PROTECTED :: a
kono
parents:
diff changeset
17 TYPE(foo), SAVE, PROTECTED, POINTER :: b
kono
parents:
diff changeset
18 INTEGER, SAVE, PROTECTED :: i = 5
kono
parents:
diff changeset
19 INTEGER, SAVE, PROTECTED, POINTER :: j => NULL()
kono
parents:
diff changeset
20 contains
kono
parents:
diff changeset
21 subroutine alloc()
kono
parents:
diff changeset
22 allocate(b,j)
kono
parents:
diff changeset
23 end subroutine alloc
kono
parents:
diff changeset
24 END MODULE amod
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 PROGRAM test
kono
parents:
diff changeset
27 USE amod
kono
parents:
diff changeset
28 IMPLICIT NONE
kono
parents:
diff changeset
29 INTEGER, TARGET :: k
kono
parents:
diff changeset
30 TYPE(foo), TARGET :: c
kono
parents:
diff changeset
31 k = 2 ! local
kono
parents:
diff changeset
32 c%i = 9 ! local
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 call alloc()
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 i = k ! { dg-error "is PROTECTED" }
kono
parents:
diff changeset
37 j => k ! { dg-error "is PROTECTED" }
kono
parents:
diff changeset
38 j = 3 ! OK 1
kono
parents:
diff changeset
39 a = c ! { dg-error "is PROTECTED" }
kono
parents:
diff changeset
40 a%i = k ! { dg-error "is PROTECTED" }
kono
parents:
diff changeset
41 a%j => k ! { dg-error "is PROTECTED" }
kono
parents:
diff changeset
42 a%j = 5 ! OK 2
kono
parents:
diff changeset
43 b => c ! { dg-error "is PROTECTED" }
kono
parents:
diff changeset
44 b%i = k ! OK 3
kono
parents:
diff changeset
45 b%j => k ! OK 4
kono
parents:
diff changeset
46 b%j = 5 ! OK 5
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 END PROGRAM test