1+ ! RUN: %python %S/test_errors.py %s %flang_fc1
2+
3+ module m
4+ type :: t1
5+ real :: x
6+ end type
7+ type :: t2(k)
8+ integer , kind :: k
9+ real (kind= k) :: x
10+ end type
11+ type :: t3
12+ real :: x
13+ end type
14+ type, extends(t1) :: t4
15+ integer :: y
16+ end type
17+ type :: t5
18+ sequence
19+ integer :: x
20+ integer :: y
21+ end type
22+
23+
24+ integer :: i
25+ real :: r
26+ type (t1) :: x1, y1
27+ type (t2(4 )) :: x24, y24
28+ type (t2(8 )) :: x28
29+ type (t3) :: x3
30+ type (t4) :: x4
31+ type (t5) :: x5
32+ class(t1), allocatable :: a1
33+ class(t3), allocatable :: a3
34+
35+
36+ logical :: t1_1 = same_type_as(x1, x1)
37+ logical :: t1_2 = same_type_as(x1, y1)
38+ logical :: t1_3 = same_type_as(x24, x24)
39+ logical :: t1_4 = same_type_as(x24, y24)
40+ logical :: t1_5 = same_type_as(x24, x28) ! ignores parameter
41+ logical :: t1_6 = .not. same_type_as(x1, x3)
42+ logical :: t1_7 = .not. same_type_as(a1, a3)
43+ ! ERROR: Actual argument for 'a=' has bad type 't5', expected extensible derived or unlimited polymorphic type
44+ logical :: t1_8 = same_type_as(x5, x5)
45+ ! ERROR: Actual argument for 'a=' has bad type 't5', expected extensible derived or unlimited polymorphic type
46+ logical :: t1_9 = same_type_as(x5, x1)
47+ ! ERROR: Actual argument for 'b=' has bad type 't5', expected extensible derived or unlimited polymorphic type
48+ logical :: t1_10 = same_type_as(x1, x5)
49+ ! ERROR: Actual argument for 'a=' has bad type 'INTEGER(4)', expected extensible derived or unlimited polymorphic type
50+ logical :: t1_11 = same_type_as(i, i)
51+ ! ERROR: Actual argument for 'a=' has bad type 'REAL(4)', expected extensible derived or unlimited polymorphic type
52+ logical :: t1_12 = same_type_as(r, r)
53+ ! ERROR: Actual argument for 'a=' has bad type 'INTEGER(4)', expected extensible derived or unlimited polymorphic type
54+ logical :: t1_13 = same_type_as(i, t)
55+
56+ logical :: t2_1 = extends_type_of(x1, y1)
57+ logical :: t2_2 = extends_type_of(x24, x24)
58+ logical :: t2_3 = extends_type_of(x24, y24)
59+ logical :: t2_4 = extends_type_of(x24, x28) ! ignores parameter
60+ logical :: t2_5 = .not. extends_type_of(x1, x3)
61+ logical :: t2_6 = .not. extends_type_of(a1, a3)
62+ logical :: t2_7 = .not. extends_type_of(x1, x4)
63+ logical :: t2_8 = extends_type_of(x4, x1)
64+ ! ERROR: Actual argument for 'a=' has bad type 't5', expected extensible derived or unlimited polymorphic type
65+ logical :: t2_9 = extends_type_of(x5, x5)
66+ ! ERROR: Actual argument for 'a=' has bad type 't5', expected extensible derived or unlimited polymorphic type
67+ logical :: t2_10 = extends_type_of(x5, x1)
68+ ! ERROR: Actual argument for 'mold=' has bad type 't5', expected extensible derived or unlimited polymorphic type
69+ logical :: t2_11 = extends_type_of(x1, x5)
70+ end module
71+
0 commit comments