| ! { dg-do compile } |
| module c_funloc_tests_2 |
| use, intrinsic :: iso_c_binding, only: c_funptr, c_funloc |
| implicit none |
| |
| contains |
| recursive subroutine sub0() bind(c) |
| type(c_funptr) :: my_c_funptr |
| integer :: my_local_variable |
| |
| my_c_funptr = c_funloc() ! { dg-error "Missing actual argument 'x' in call to 'c_funloc'" } |
| my_c_funptr = c_funloc(sub0) |
| my_c_funptr = c_funloc(sub0, sub0) ! { dg-error "Too many arguments in call to 'c_funloc'" } |
| 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" } |
| end subroutine sub0 |
| end module c_funloc_tests_2 |