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_AlarmWriteRestart(alarm,keywordEnforcer,rc)! !ARGUMENTS:type(ESMF_Alarm),intent(in)::alarmtype(ESMF_KeywordEnforcer),optional::keywordEnforcer! must use keywords belowinteger,intent(out),optional::rc! !DESCRIPTION:! Saves an {\tt ESMF\_Alarm} object. Default options are to select the! fastest way to save to disk. (Not implemented yet).!! The arguments are:! \begin{description}! \item[alarm]! The object instance to save.! \item[{[rc]}]! Return code; equals {\tt ESMF\_SUCCESS} if there are no errors.! \end{description}!!EOPI! !REQUIREMENTS:integer::localrc! local return code! Assume failure until successif(present(rc))rc=ESMF_RC_NOT_IMPLlocalrc=ESMF_RC_NOT_IMPL! check inputESMF_INIT_CHECK_DEEP(ESMF_AlarmGetInit,alarm,rc)! invoke C to C++ entry pointcall c_ESMC_AlarmWriteRestart(alarm,localrc)if(ESMF_LogFoundError(localrc,ESMF_ERR_PASSTHRU,&ESMF_CONTEXT,rcToReturn=rc))return! Return successif(present(rc))rc=ESMF_SUCCESSend subroutine ESMF_AlarmWriteRestart