subroutine ESMF_InfoGetR4(info, key, value, keywordEnforcer, default, idx, attnestflag, rc)
type(ESMF_Info), intent(in) :: info
character(len=*), intent(in) :: key
real(ESMF_KIND_R4), intent(out) :: value
type(ESMF_KeywordEnforcer), optional:: keywordEnforcer ! must use keywords below
real(ESMF_KIND_R4), intent(in), optional :: default
integer, intent(in), optional :: idx
type(ESMF_AttNest_Flag), intent(in), optional :: attnestflag
integer, intent(out), optional :: rc
integer :: localrc
real(C_FLOAT), target :: local_default
integer(C_INT), target :: local_idx
type(C_PTR) :: local_default_ptr, local_idx_ptr
integer(C_INT) :: recursive, strlen_only
! Set up local return code
localrc = ESMF_FAILURE
if (present(rc)) rc = ESMF_FAILURE
recursive = 0 !false
strlen_only = 0 !false
! Handle optional arguments for C ###########################################
if (present(default)) then
local_default = default
local_default_ptr = C_LOC(local_default)
else
local_default_ptr = C_NULL_PTR
end if
if (present(idx)) then
local_idx = idx - 1 ! Shift to C (zero-based) indexing
local_idx_ptr = C_LOC(local_idx)
else
local_idx_ptr = C_NULL_PTR
end if
if (present(attnestflag)) then
if (attnestflag%value==ESMF_ATTNEST_ON%value) recursive = 1 !true
end if
! Call C ####################################################################
call c_info_get_R4(&
info%ptr, &
trim(key)//C_NULL_CHAR, &
value, &
localrc, &
local_default_ptr, &
local_idx_ptr, &
recursive)
if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, ESMF_CONTEXT, rcToReturn=rc)) return
if (present(rc)) rc = ESMF_SUCCESS
end subroutine ESMF_InfoGetR4