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