1! { dg-do compile } 2module c_funloc_tests_2 3 use, intrinsic :: iso_c_binding, only: c_funptr, c_funloc 4 implicit none 5 6contains 7 recursive subroutine sub0() bind(c) 8 type(c_funptr) :: my_c_funptr 9 integer :: my_local_variable 10 11 my_c_funptr = c_funloc() ! { dg-error "Missing actual argument 'x' in call to 'c_funloc'" } 12 my_c_funptr = c_funloc(sub0) 13 my_c_funptr = c_funloc(sub0, sub0) ! { dg-error "Too many arguments in call to 'c_funloc'" } 14 my_c_funptr = c_funloc(my_local_variable) ! { dg-error "Argument X at .1. to C_FUNLOC shall be a procedure or a procedure pointer" } 15 end subroutine sub0 16end module c_funloc_tests_2 17