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_CompClassValidate(cc,rc)!! !ARGUMENTS:type(ESMF_CompClass),intent(in)::ccinteger,intent(out),optional::rc! !! !DESCRIPTION:! Validates that the {\tt CompClass} is internally consistent.! The method returns an error code if problems are found. !! The arguments are:! \begin{description}! \item[cc] ! Specified {\tt ESMF\_CompClass} object.! \item[{[rc]}] ! Return code; equals {\tt ESMF\_SUCCESS} if there are no errors.! \end{description}!!EOPI!------------------------------------------------------------------------------integer::localrc! local return code! Assume not implemented until successif(present(rc))rc=ESMF_RC_NOT_IMPLlocalrc=ESMF_RC_NOT_IMPL! Check init status of argumentsESMF_INIT_CHECK_DEEP(ESMF_CompClassGetInit,cc,rc)! Call into the C++ interface, which will sort out optional arguments.!todo: call c_ESMC_CompClassValidate(cc, localrc)! Use LogErr to handle return code (ESMF_SUCCESS for Validate)! if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, &! ESMF_CONTEXT, rcToReturn=rc)) return! Return successif(present(rc))rc=ESMF_SUCCESSend subroutine ESMF_CompClassValidate