Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
type(ESMF_Info), | intent(inout) | :: | info | |||
character(len=*), | intent(in) | :: | key | |||
logical, | intent(in), | dimension(:) | :: | values | ||
type(ESMF_KeywordEnforcer), | optional | :: | keywordEnforcer | |||
logical, | intent(in), | optional | :: | force | ||
character(len=*), | intent(in), | optional | :: | pkey | ||
integer, | intent(out), | optional | :: | rc |
subroutine ESMF_InfoSetArrayLG(info, key, values, keywordEnforcer, force, pkey, rc) type(ESMF_Info), intent(inout) :: info character(len=*), intent(in) :: key logical, dimension(:), intent(in) :: values type(ESMF_KeywordEnforcer), optional:: keywordEnforcer ! must use keywords below logical, intent(in), optional :: force character(len=*), intent(in), optional :: pkey integer, intent(out), optional :: rc integer :: localrc logical(C_BOOL) :: local_force integer :: ii logical(C_BOOL), dimension(:), allocatable :: local_values character(:), allocatable :: local_pkey localrc = ESMF_FAILURE if (present(rc)) rc = ESMF_FAILURE if (present(force)) then local_force = force else local_force = .true. end if if (present(pkey)) then local_pkey = TRIM(pkey)//C_NULL_CHAR else local_pkey = ""//C_NULL_CHAR end if allocate(local_values(SIZE(values))) do ii=1,SIZE(values) local_values(ii) = values(ii) enddo call c_info_set_array_LG(& info%ptr, & trim(key)//C_NULL_CHAR, & local_values, & SIZE(values), & local_force, & localrc, & local_pkey) if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, ESMF_CONTEXT, rcToReturn=rc)) return deallocate(local_values) if (present(rc)) rc = ESMF_SUCCESS end subroutine ESMF_InfoSetArrayLG