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
function ESMF_ClockEQAlias(clock1,clock2)!! !RETURN VALUE:logical::ESMF_ClockEQAlias! !ARGUMENTS:type(ESMF_Clock),intent(in)::clock1type(ESMF_Clock),intent(in)::clock2! !DESCRIPTION:! This method overloads the (==) operator for the {\tt ESMF\_Clock}! class. See "interface operator(==)" above for complete description.!!EOPIESMF_INIT_TYPEclockinit1,clockinit2integer::localrc1,localrc2logical::lval1,lval2! Use the following logic, rather than "ESMF-INIT-CHECK-DEEP", to gain! init checks on both args, and in the case where both are uninitialized,! to distinguish equality based on uninitialized type (uncreated,! deleted).! TODO: Consider moving this logic to C++: use Base class? status?! Or replicate logic for C interface also.! check inputsclockinit1=ESMF_ClockGetInit(clock1)clockinit2=ESMF_ClockGetInit(clock2)if(clockinit1.eq.ESMF_INIT_CREATED.and.&clockinit2.eq.ESMF_INIT_CREATED)thenESMF_ClockEQAlias=clock1%this.eq.clock2%thiselseESMF_ClockEQAlias=.false.endif end function ESMF_ClockEQAlias