! RUN: %python %S/test_errors.py %s %flang_fc1 -pedantic ! Enforce C_F_STRPOINTER semantics (18.2.3.5) program test use iso_c_binding type(c_ptr) :: cptr character(len=:), pointer :: fstrptr character(len=1, kind=c_char), dimension(100), target :: cstrarray character(len=10), pointer :: fstrptr_not_deferred integer :: nchars ! Valid calls call c_f_strpointer(cstrarray, fstrptr) ! ok call c_f_strpointer(cstrarray, fstrptr, 50) ! ok with NCHARS call c_f_strpointer(cptr, fstrptr, 100) ! ok with CSTRPTR form call c_f_strpointer(CSTRARRAY=cstrarray, FSTRPTR=fstrptr) ! ok with CSTRARRAY keyword call c_f_strpointer(CSTRARRAY=cstrarray, FSTRPTR=fstrptr, NCHARS=50) ! ok with all keywords call c_f_strpointer(CSTRPTR=cptr, FSTRPTR=fstrptr, NCHARS=50) ! ok with all keywords ! Error: CSTRPTR form requires NCHARS !ERROR: NCHARS= argument is required when CSTRPTR= appears in C_F_STRPOINTER() call c_f_strpointer(cptr, fstrptr) ! Error: CSTRPTR form requires NCHARS (with explicit keyword) !ERROR: NCHARS= argument is required when CSTRPTR= appears in C_F_STRPOINTER() call c_f_strpointer(CSTRPTR=cptr, FSTRPTR=fstrptr) ! Error: Wrong keyword for C_PTR argument !ERROR: Keyword CSTRARRAY= cannot be used with a C_PTR argument; use CSTRPTR= instead call c_f_strpointer(CSTRARRAY=cptr, FSTRPTR=fstrptr, NCHARS=10) ! Error: Wrong keyword for character array argument !ERROR: Keyword CSTRPTR= cannot be used with a character array argument; use CSTRARRAY= instead call c_f_strpointer(CSTRPTR=cstrarray, FSTRPTR=fstrptr, NCHARS=50) ! Error: FSTRPTR must have deferred length !ERROR: FSTRPTR= argument to C_F_STRPOINTER() must have deferred length call c_f_strpointer(cstrarray, fstrptr_not_deferred) ! Error: NCHARS must be non-negative !ERROR: NCHARS= argument to C_F_STRPOINTER() must be non-negative call c_f_strpointer(cstrarray, fstrptr, -5) ! Error: NCHARS greater than array size (compile-time check) !ERROR: NCHARS=150 is greater than the size of CSTRARRAY=100 in C_F_STRPOINTER() call c_f_strpointer(cstrarray, fstrptr, 150) ! Error: Missing required argument FSTRPTR !ERROR: Dummy argument 'fstrptr=' is absent and not OPTIONAL call c_f_strpointer(cstrarray) ! Error: Missing both required arguments !ERROR: Dummy argument 'cstr=' is absent and not OPTIONAL !ERROR: Dummy argument 'fstrptr=' is absent and not OPTIONAL call c_f_strpointer() ! Error: Too many arguments !ERROR: Too many actual arguments (4 > 3) call c_f_strpointer(cstrarray, fstrptr, 50, 999) end program subroutine test_assumed_size(cstrarray_assumed, fstrptr) use iso_c_binding character(len=1, kind=c_char), dimension(*), target, intent(in) :: cstrarray_assumed character(len=:), pointer :: fstrptr ! Error: Assumed-size requires NCHARS !ERROR: NCHARS= argument is required when CSTRARRAY= is assumed-size in C_F_STRPOINTER() call c_f_strpointer(cstrarray_assumed, fstrptr) ! Valid: Assumed-size with NCHARS call c_f_strpointer(cstrarray_assumed, fstrptr, 100) end subroutine