Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed
arrows point from an interface to procedures which implement that interface.
This could include the module procedures in a generic interface or the
implementation in a submodule of an interface in a parent module.
Where possible, edges connecting nodes are
given different colours to make them easier to distinguish in
large graphs.
Source Code
subroutine ESMF_GetVM(base,vm,rc)!! !ARGUMENTS:type(ESMF_Base),intent(in)::basetype(ESMF_VM),intent(out)::vminteger,intent(out),optional::rc!! !DESCRIPTION:! Return the vm of any type in the system.!! The arguments are:! \begin{description}! \item[base]! Any ESMF type.! \item[vm]! The vm on which the Base object was created.! \item[{[rc]}]! Return code; equals {\tt ESMF\_SUCCESS} if there are no errors.! \end{description}!!EOPIinteger::localrc! Initialize return code; assume routine not implementedif(present(rc))rc=ESMF_RC_NOT_IMPLlocalrc=ESMF_RC_NOT_IMPL! access the VM from the C++ sidecall c_ESMC_GetVM(base,vm,localrc)if(present(rc))rc=localrc! Set init codecall ESMF_VMSetInitCreated(vm,rc=localrc)if(ESMF_LogFoundError(localrc,ESMF_ERR_PASSTHRU,&ESMF_CONTEXT,rcToReturn=rc))return! return successfullyif(present(rc))rc=ESMF_SUCCESSend subroutine ESMF_GetVM