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.
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
recursive subroutine ESMF_VMShutdown(vm,vmplan,vm_info,rc)!! !ARGUMENTS:type(ESMF_VM),intent(in)::vmtype(ESMF_VMPlan),intent(in)::vmplantype(ESMF_Pointer),intent(inout)::vm_infointeger,intent(out),optional::rc!! !DESCRIPTION:! Shutdown a VM.!! The arguments are:! \begin{description}! \item[{[rc]}] ! Return code; equals {\tt ESMF\_SUCCESS} if there are no errors.! \end{description}!!EOPI!------------------------------------------------------------------------------integer::localrc! local return code! initialize return code; assume routine not implementedlocalrc=ESMF_RC_NOT_IMPLif(present(rc))rc=ESMF_RC_NOT_IMPL! Check init status of argumentsESMF_INIT_CHECK_DEEP(ESMF_VMGetInit,vm,rc)ESMF_INIT_CHECK_DEEP(ESMF_VMPlanGetInit,vmplan,rc)! Call into the C++ interface.call c_ESMC_VMShutdown(vm,vmplan,vm_info,localrc)if(ESMF_LogFoundError(localrc,ESMF_ERR_PASSTHRU,&ESMF_CONTEXT,rcToReturn=rc))return! return successfullyif(present(rc))rc=ESMF_SUCCESSend subroutine ESMF_VMShutdown