xref: /llvm-project/flang/test/Semantics/lcobound.f90 (revision 94963919011d77c2f3f9d867cb73067a4f50e87c)
1565f5dfaSDamian Rouson! RUN: %python %S/test_errors.py %s %flang_fc1
2565f5dfaSDamian Rouson! Check for semantic errors in lcobound() function references
3565f5dfaSDamian Rouson
4565f5dfaSDamian Rousonprogram lcobound_tests
57dbbf77eSKatherine Rasmussen  use iso_c_binding, only : c_int32_t, c_int64_t
6565f5dfaSDamian Rouson  implicit none
7565f5dfaSDamian Rouson
8565f5dfaSDamian Rouson  integer n, i, array(1), non_coarray(1), scalar_coarray[*], array_coarray(1)[*], non_constant, scalar
97dbbf77eSKatherine Rasmussen  integer, parameter :: const_out_of_range_dim = 5, const_in_range_dim = 1
107dbbf77eSKatherine Rasmussen  real, allocatable :: coarray_corank3[:,:,:]
117dbbf77eSKatherine Rasmussen  logical non_integer, logical_coarray[3,*]
127dbbf77eSKatherine Rasmussen  logical, parameter :: const_non_integer = .true.
13565f5dfaSDamian Rouson  integer, allocatable :: lcobounds(:)
14*94963919SPeter Klausler  real bounded[2:3,4:5,*]
15*94963919SPeter Klausler
16*94963919SPeter Klausler  integer(kind=merge(kind(1),-1,all(lcobound(bounded)==[2,4,1]))) test_lcobound
17565f5dfaSDamian Rouson
18565f5dfaSDamian Rouson  !___ standard-conforming statement with no optional arguments present ___
19565f5dfaSDamian Rouson  lcobounds = lcobound(scalar_coarray)
20565f5dfaSDamian Rouson  lcobounds = lcobound(array_coarray)
217dbbf77eSKatherine Rasmussen  lcobounds = lcobound(coarray_corank3)
227dbbf77eSKatherine Rasmussen  lcobounds = lcobound(logical_coarray)
23565f5dfaSDamian Rouson  lcobounds = lcobound(coarray=scalar_coarray)
24565f5dfaSDamian Rouson
25565f5dfaSDamian Rouson  !___ standard-conforming statements with optional dim argument present ___
26565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, 1)
277dbbf77eSKatherine Rasmussen  n = lcobound(coarray_corank3, 1)
287dbbf77eSKatherine Rasmussen  n = lcobound(coarray_corank3, 3)
297dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, const_in_range_dim)
307dbbf77eSKatherine Rasmussen  n = lcobound(logical_coarray, const_in_range_dim)
31565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, dim=1)
32565f5dfaSDamian Rouson  n = lcobound(coarray=scalar_coarray, dim=1)
33565f5dfaSDamian Rouson  n = lcobound( dim=1, coarray=scalar_coarray)
34565f5dfaSDamian Rouson
35565f5dfaSDamian Rouson  !___ standard-conforming statements with optional kind argument present ___
36565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, 1, c_int32_t)
37565f5dfaSDamian Rouson
38565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, 1, kind=c_int32_t)
39565f5dfaSDamian Rouson
40565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, dim=1, kind=c_int32_t)
41565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, kind=c_int32_t, dim=1)
42565f5dfaSDamian Rouson
43565f5dfaSDamian Rouson  lcobounds = lcobound(scalar_coarray, kind=c_int32_t)
44565f5dfaSDamian Rouson
45565f5dfaSDamian Rouson  lcobounds = lcobound(coarray=scalar_coarray, kind=c_int32_t)
46565f5dfaSDamian Rouson  lcobounds = lcobound(kind=c_int32_t, coarray=scalar_coarray)
47565f5dfaSDamian Rouson
48565f5dfaSDamian Rouson  n = lcobound(coarray=scalar_coarray, dim=1, kind=c_int32_t)
49565f5dfaSDamian Rouson  n = lcobound(dim=1, coarray=scalar_coarray, kind=c_int32_t)
50565f5dfaSDamian Rouson  n = lcobound(kind=c_int32_t, coarray=scalar_coarray, dim=1)
51565f5dfaSDamian Rouson  n = lcobound(dim=1, kind=c_int32_t, coarray=scalar_coarray)
52565f5dfaSDamian Rouson  n = lcobound(kind=c_int32_t, dim=1, coarray=scalar_coarray)
53565f5dfaSDamian Rouson
54565f5dfaSDamian Rouson  !___ non-conforming statements ___
557dbbf77eSKatherine Rasmussen
56*94963919SPeter Klausler  !ERROR: DIM=0 dimension must be positive
577dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, dim=0)
587dbbf77eSKatherine Rasmussen
59*94963919SPeter Klausler  !ERROR: DIM=0 dimension must be positive
607dbbf77eSKatherine Rasmussen  n = lcobound(coarray_corank3, dim=0)
617dbbf77eSKatherine Rasmussen
62*94963919SPeter Klausler  !ERROR: DIM=-1 dimension must be positive
637dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, dim=-1)
647dbbf77eSKatherine Rasmussen
65*94963919SPeter Klausler  !ERROR: DIM=2 dimension is out of range for corank-1 coarray
66565f5dfaSDamian Rouson  n = lcobound(array_coarray, dim=2)
677dbbf77eSKatherine Rasmussen
68*94963919SPeter Klausler  !ERROR: DIM=2 dimension is out of range for corank-1 coarray
697dbbf77eSKatherine Rasmussen  n = lcobound(array_coarray, 2)
707dbbf77eSKatherine Rasmussen
71*94963919SPeter Klausler  !ERROR: DIM=4 dimension is out of range for corank-3 coarray
727dbbf77eSKatherine Rasmussen  n = lcobound(coarray_corank3, dim=4)
737dbbf77eSKatherine Rasmussen
74*94963919SPeter Klausler  !ERROR: DIM=4 dimension is out of range for corank-3 coarray
757dbbf77eSKatherine Rasmussen  n = lcobound(dim=4, coarray=coarray_corank3)
767dbbf77eSKatherine Rasmussen
77*94963919SPeter Klausler  !ERROR: DIM=5 dimension is out of range for corank-3 coarray
787dbbf77eSKatherine Rasmussen  n = lcobound(coarray_corank3, const_out_of_range_dim)
797dbbf77eSKatherine Rasmussen
807dbbf77eSKatherine Rasmussen  !ERROR: No intrinsic or user-defined ASSIGNMENT(=) matches scalar INTEGER(4) and rank 1 array of INTEGER(4)
81565f5dfaSDamian Rouson  scalar = lcobound(scalar_coarray)
82565f5dfaSDamian Rouson
837dbbf77eSKatherine Rasmussen  !ERROR: missing mandatory 'coarray=' argument
84565f5dfaSDamian Rouson  n = lcobound(dim=i)
85565f5dfaSDamian Rouson
867dbbf77eSKatherine Rasmussen  !ERROR: Actual argument for 'dim=' has bad type 'LOGICAL(4)'
87565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, non_integer)
88565f5dfaSDamian Rouson
897dbbf77eSKatherine Rasmussen  !ERROR: Actual argument for 'dim=' has bad type 'LOGICAL(4)'
90565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, dim=non_integer)
91565f5dfaSDamian Rouson
927dbbf77eSKatherine Rasmussen  !ERROR: Actual argument for 'kind=' has bad type 'LOGICAL(4)'
937dbbf77eSKatherine Rasmussen  lcobounds = lcobound(scalar_coarray, kind=const_non_integer)
947dbbf77eSKatherine Rasmussen
957dbbf77eSKatherine Rasmussen  !ERROR: Actual argument for 'kind=' has bad type 'LOGICAL(4)'
967dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, 1, const_non_integer)
977dbbf77eSKatherine Rasmussen
987dbbf77eSKatherine Rasmussen  !ERROR: 'kind=' argument must be a constant scalar integer whose value is a supported kind for the intrinsic result type
99565f5dfaSDamian Rouson  lcobounds = lcobound(scalar_coarray, kind=non_constant)
100565f5dfaSDamian Rouson
1017dbbf77eSKatherine Rasmussen  !ERROR: 'kind=' argument must be a constant scalar integer whose value is a supported kind for the intrinsic result type
1027dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, dim=1, kind=non_constant)
1037dbbf77eSKatherine Rasmussen
1047dbbf77eSKatherine Rasmussen  !ERROR: 'kind=' argument must be a constant scalar integer whose value is a supported kind for the intrinsic result type
1057dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, 1, non_constant)
1067dbbf77eSKatherine Rasmussen
1077dbbf77eSKatherine Rasmussen  !ERROR: missing mandatory 'coarray=' argument
108565f5dfaSDamian Rouson  n = lcobound(dim=i, kind=c_int32_t)
109565f5dfaSDamian Rouson
110e3b6b929SPeter Klausler  !ERROR: actual argument #2 without a keyword may not follow an actual argument with a keyword
111565f5dfaSDamian Rouson  n = lcobound(coarray=scalar_coarray, i)
112565f5dfaSDamian Rouson
113e3b6b929SPeter Klausler  n = lcobound(coarray=scalar_coarray, dim=i)
114e3b6b929SPeter Klausler
1157dbbf77eSKatherine Rasmussen  !ERROR: missing mandatory 'coarray=' argument
1167dbbf77eSKatherine Rasmussen  lcobounds = lcobound()
1177dbbf77eSKatherine Rasmussen
1187dbbf77eSKatherine Rasmussen  !ERROR: 'coarray=' argument must have corank > 0 for intrinsic 'lcobound'
119565f5dfaSDamian Rouson  lcobounds = lcobound(3.4)
120565f5dfaSDamian Rouson
1217dbbf77eSKatherine Rasmussen  !ERROR: keyword argument to intrinsic 'lcobound' was supplied positionally by an earlier actual argument
1227dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, 1, coarray=scalar_coarray)
1237dbbf77eSKatherine Rasmussen
1247dbbf77eSKatherine Rasmussen  !ERROR: too many actual arguments for intrinsic 'lcobound'
125565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, i, c_int32_t, 0)
126565f5dfaSDamian Rouson
1277dbbf77eSKatherine Rasmussen  !ERROR: 'coarray=' argument must have corank > 0 for intrinsic 'lcobound'
128565f5dfaSDamian Rouson  lcobounds = lcobound(coarray=non_coarray)
129565f5dfaSDamian Rouson
1307dbbf77eSKatherine Rasmussen  !ERROR: 'coarray=' argument must have corank > 0 for intrinsic 'lcobound'
1317dbbf77eSKatherine Rasmussen  n = lcobound(coarray=non_coarray, dim=1)
132565f5dfaSDamian Rouson
1337dbbf77eSKatherine Rasmussen  !ERROR: 'dim=' argument has unacceptable rank 1
134565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, array )
135565f5dfaSDamian Rouson
1367dbbf77eSKatherine Rasmussen  !ERROR: unknown keyword argument to intrinsic 'lcobound'
137565f5dfaSDamian Rouson  lcobounds = lcobound(c=scalar_coarray)
138565f5dfaSDamian Rouson
1397dbbf77eSKatherine Rasmussen  !ERROR: unknown keyword argument to intrinsic 'lcobound'
140565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, dims=i)
141565f5dfaSDamian Rouson
1427dbbf77eSKatherine Rasmussen  !ERROR: unknown keyword argument to intrinsic 'lcobound'
143565f5dfaSDamian Rouson  n = lcobound(scalar_coarray, i, kinds=c_int32_t)
144565f5dfaSDamian Rouson
1457dbbf77eSKatherine Rasmussen  !ERROR: repeated keyword argument to intrinsic 'lcobound'
1467dbbf77eSKatherine Rasmussen  n = lcobound(scalar_coarray, dim=1, dim=2)
1477dbbf77eSKatherine Rasmussen
1487dbbf77eSKatherine Rasmussen  !ERROR: repeated keyword argument to intrinsic 'lcobound'
1497dbbf77eSKatherine Rasmussen  lcobounds = lcobound(coarray=scalar_coarray, coarray=array_coarray)
1507dbbf77eSKatherine Rasmussen
1517dbbf77eSKatherine Rasmussen  !ERROR: repeated keyword argument to intrinsic 'lcobound'
1527dbbf77eSKatherine Rasmussen  lcobounds = lcobound(scalar_coarray, kind=c_int32_t, kind=c_int64_t)
1537dbbf77eSKatherine Rasmussen
154565f5dfaSDamian Rousonend program lcobound_tests
155