[flang] Accept polymorphic component element in storage_size
[llvm-project.git] / flang / test / Semantics / resolve21.f90
blob3be7602b539d2f4e394b2d5453d3015e140694d7
1 ! RUN: %python %S/test_errors.py %s %flang_fc1
2 subroutine s1
3 type :: t
4 integer :: i
5 integer :: s1
6 integer :: t
7 end type
8 !ERROR: 't' is already declared in this scoping unit
9 integer :: t
10 integer :: i, j
11 type(t) :: x
12 !ERROR: Derived type 't2' not found
13 type(t2) :: y
14 external :: v
15 type(t) :: v, w
16 external :: w
17 !ERROR: 'z' is not an object of derived type; it is implicitly typed
18 i = z%i
19 !ERROR: 's1' is an invalid base for a component reference
20 i = s1%i
21 !ERROR: 'j' is not an object of derived type
22 i = j%i
23 !ERROR: Component 'j' not found in derived type 't'
24 i = x%j
25 !ERROR: 'v' is an invalid base for a component reference
26 i = v%i
27 !ERROR: 'w' is an invalid base for a component reference
28 i = w%i
29 i = x%i !OK
30 end subroutine
32 subroutine s2
33 type :: t1
34 integer :: i
35 end type
36 type :: t2
37 type(t1) :: x
38 end type
39 type(t2) :: y
40 integer :: i
41 !ERROR: Component 'j' not found in derived type 't1'
42 k = y%x%j
43 k = y%x%i !OK
44 end subroutine