Я пытаюсь написать общую процедуру с привязкой к типу, которая принимает в качестве параметров различные функции обратного вызова. При компиляции следующего кода (с ifort 12.1.3) я получаю следующее предупреждение:
module test
type :: a_type
contains
procedure :: t_s => at_s
procedure :: t_d => at_d
generic :: t => t_s,t_d
end type a_type
abstract interface
integer function cb_s(arg)
real(4) :: arg
end function cb_s
integer function cb_d(arg)
real(8) :: arg
end function cb_d
end interface
contains
subroutine at_s(this,cb)
class(a_type) :: this
procedure(cb_s) :: cb
end subroutine
subroutine at_d(this,cb)
class(a_type) :: this
procedure(cb_d) :: cb
end subroutine
end module test
Предупреждение:
compileme.f(27): warning #8449: The type/rank/keyword signature for this specific
procedure matches another specific procedure that shares the same generic
binding name. [AT_D]
Похоже, что компилятор не различает разные интерфейсы функций при использовании в качестве аргументов процедуры...
Мой вопрос: почему эти типы не проверяются и каков правильный и чистый способ написания общих процедур с привязкой к типу с процедурами или указателями процедур в качестве аргументов?
Возможное решение
Как отметил Владимир Ф., проверяются только возвращаемые аргументы функции обратного вызова. В моем случае можно просто немного изменить интерфейсы функций:
abstract interface
real(4) function cb_s(arg)
real(4) :: arg
end function cb_s
real(8) function cb_d(arg)
real(8) :: arg
end function cb_d
end interface