ESMF_InfoGetArrayR4Alloc Subroutine

private subroutine ESMF_InfoGetArrayR4Alloc(info, key, values, keywordEnforcer, itemCount, attnestflag, scalarToArray, rc)

Arguments

Type IntentOptional Attributes Name
type(ESMF_Info), intent(in) :: info
character(len=*), intent(in) :: key
real(kind=ESMF_KIND_R4), intent(out), dimension(:), allocatable :: values
type(ESMF_KeywordEnforcer), optional :: keywordEnforcer
integer, intent(out), optional :: itemCount
type(ESMF_AttNest_Flag), intent(in), optional :: attnestflag
logical, intent(in), optional :: scalarToArray
integer, intent(out), optional :: rc

Calls

proc~~esmf_infogetarrayr4alloc~~CallsGraph proc~esmf_infogetarrayr4alloc ESMF_InfoGetArrayR4Alloc interface~c_info_get_array_r4 c_info_get_array_R4 proc~esmf_infogetarrayr4alloc->interface~c_info_get_array_r4 proc~esmf_infogetarraymeta ESMF_InfoGetArrayMeta proc~esmf_infogetarrayr4alloc->proc~esmf_infogetarraymeta proc~esmf_logfounderror ESMF_LogFoundError proc~esmf_infogetarrayr4alloc->proc~esmf_logfounderror proc~esmf_infogetarraymeta->proc~esmf_logfounderror interface~c_info_get_array_meta c_info_get_array_meta proc~esmf_infogetarraymeta->interface~c_info_get_array_meta esmf_breakpoint esmf_breakpoint proc~esmf_logfounderror->esmf_breakpoint proc~esmf_logrc2msg ESMF_LogRc2Msg proc~esmf_logfounderror->proc~esmf_logrc2msg proc~esmf_logwrite ESMF_LogWrite proc~esmf_logfounderror->proc~esmf_logwrite c_esmc_loggeterrormsg c_esmc_loggeterrormsg proc~esmf_logrc2msg->c_esmc_loggeterrormsg c_esmc_vmwtime c_esmc_vmwtime proc~esmf_logwrite->c_esmc_vmwtime proc~esmf_logclose ESMF_LogClose proc~esmf_logwrite->proc~esmf_logclose proc~esmf_logflush ESMF_LogFlush proc~esmf_logwrite->proc~esmf_logflush proc~esmf_logopenfile ESMF_LogOpenFile proc~esmf_logwrite->proc~esmf_logopenfile proc~esmf_utiliounitflush ESMF_UtilIOUnitFlush proc~esmf_logwrite->proc~esmf_utiliounitflush proc~esmf_utilstring2array ESMF_UtilString2Array proc~esmf_logwrite->proc~esmf_utilstring2array proc~esmf_logclose->proc~esmf_logflush proc~esmf_logflush->proc~esmf_utiliounitflush proc~esmf_utilarray2string ESMF_UtilArray2String proc~esmf_logflush->proc~esmf_utilarray2string proc~esmf_logopenfile->proc~esmf_utiliounitflush proc~esmf_utiliounitget ESMF_UtilIOUnitGet proc~esmf_logopenfile->proc~esmf_utiliounitget

Called by

proc~~esmf_infogetarrayr4alloc~~CalledByGraph proc~esmf_infogetarrayr4alloc ESMF_InfoGetArrayR4Alloc interface~esmf_infogetalloc ESMF_InfoGetAlloc interface~esmf_infogetalloc->proc~esmf_infogetarrayr4alloc proc~nuopc_cplcompsearchrevphasemap NUOPC_CplCompSearchRevPhaseMap proc~nuopc_cplcompsearchrevphasemap->interface~esmf_infogetalloc proc~nuopc_gridcompsearchrevphasemap NUOPC_GridCompSearchRevPhaseMap proc~nuopc_gridcompsearchrevphasemap->interface~esmf_infogetalloc program~esmf_infoarrayutest ESMF_InfoArrayUTest program~esmf_infoarrayutest->interface~esmf_infogetalloc program~esmf_infotutorial ESMF_InfoTutorial program~esmf_infotutorial->interface~esmf_infogetalloc program~esmf_infoutest ESMF_InfoUTest program~esmf_infoutest->interface~esmf_infogetalloc interface~nuopc_compsearchrevphasemap NUOPC_CompSearchRevPhaseMap interface~nuopc_compsearchrevphasemap->proc~nuopc_cplcompsearchrevphasemap interface~nuopc_compsearchrevphasemap->proc~nuopc_gridcompsearchrevphasemap proc~finalizereset FinalizeReset proc~finalizereset->interface~nuopc_compsearchrevphasemap proc~finalize~10 Finalize proc~finalize~10->interface~nuopc_compsearchrevphasemap proc~finalize~2 Finalize proc~finalize~2->interface~nuopc_compsearchrevphasemap proc~initializeipdv02p1 InitializeIPDv02p1 proc~initializeipdv02p1->interface~nuopc_compsearchrevphasemap proc~loopconnectorcompss loopConnectorCompsS proc~loopconnectorcompss->interface~nuopc_compsearchrevphasemap proc~loopmodelcompss loopModelCompsS proc~loopmodelcompss->interface~nuopc_compsearchrevphasemap proc~nuopc_comphandleverbosityextro NUOPC_CompHandleVerbosityExtro proc~nuopc_comphandleverbosityextro->interface~nuopc_compsearchrevphasemap proc~nuopc_comphandleverbosityintro NUOPC_CompHandleVerbosityIntro proc~nuopc_comphandleverbosityintro->interface~nuopc_compsearchrevphasemap proc~routine_executecplcomp routine_executeCplComp proc~routine_executecplcomp->interface~nuopc_compsearchrevphasemap proc~routine_executegridcomp routine_executeGridComp proc~routine_executegridcomp->interface~nuopc_compsearchrevphasemap proc~routine_run routine_Run proc~routine_run->interface~nuopc_compsearchrevphasemap proc~routine_run~2 routine_Run proc~routine_run~2->interface~nuopc_compsearchrevphasemap proc~run Run proc~run->interface~nuopc_compsearchrevphasemap program~esmf_nuopc_utest ESMF_NUOPC_UTest program~esmf_nuopc_utest->interface~nuopc_compsearchrevphasemap

Source Code

subroutine ESMF_InfoGetArrayR4Alloc(info, key, values, keywordEnforcer, itemCount, attnestflag, scalarToArray, rc)
  type(ESMF_Info), intent(in) :: info
  character(len=*), intent(in) :: key
  real(ESMF_KIND_R4), dimension(:),  allocatable, intent(out) :: values
type(ESMF_KeywordEnforcer), optional:: keywordEnforcer ! must use keywords below
  integer, intent(out), optional :: itemCount
  type(ESMF_AttNest_Flag), intent(in), optional :: attnestflag
  logical, intent(in), optional :: scalarToArray
  integer, intent(out), optional :: rc

  integer :: localrc
  integer(C_INT) :: recursive, local_itemCount, expected_size, local_scalarToArray
  logical :: is_array

  localrc = ESMF_FAILURE
  if (present(rc)) rc = ESMF_FAILURE
  recursive = 0 !false

  if (present(attnestflag)) then
    if (attnestflag%value==ESMF_ATTNEST_ON%value) recursive = 1 !true
  end if

  local_scalarToArray = 0 !false
  if (present(scalarToArray)) then
    if (scalarToArray) local_scalarToArray = 1 !true
  end if

  ! Set the value to a negative one to indicate we are doing an allocatable call
  ! into the storage layer, and the size should not be checked.
  expected_size = -1

  ! Get the array size from the info store
  call ESMF_InfoGetArrayMeta(info, key, is_array, local_itemcount, attnestflag=attnestflag, &
    rc=localrc)
  if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, ESMF_CONTEXT, rcToReturn=rc)) return

  ! Allocate the outgoing storage array and call into C to fill the array
  allocate(values(local_itemCount))

  call c_info_get_array_R4(&
    info%ptr, &
    trim(key)//C_NULL_CHAR, &
    values, &
    local_itemCount, &
    localrc, &
    recursive, &
    local_scalarToArray, &
    expected_size)
  if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, ESMF_CONTEXT, rcToReturn=rc)) return

  if (present(itemCount)) itemCount = local_itemCount
  if (present(rc)) rc = ESMF_SUCCESS
end subroutine ESMF_InfoGetArrayR4Alloc