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_HConfigEQ(HConfig1,HConfig2)!! !RETURN VALUE:logical::ESMF_HConfigEQ! !ARGUMENTS:type(ESMF_HConfig),intent(in)::HConfig1type(ESMF_HConfig),intent(in)::HConfig2! !DESCRIPTION:! Test if both {\tt HConfig1} and {\tt HConfig2} alias the same! ESMF HConfig object.!!EOPI!-------------------------------------------------------------------------------ESMF_INIT_TYPEinit1,init2type(ESMF_Logical)::isEqual! 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).! check inputsinit1=ESMF_HConfigGetInit(HConfig1)init2=ESMF_HConfigGetInit(HConfig2)! initialize return valueESMF_HConfigEQ=.false.! TODO: this line must remain split in two for SunOS f90 8.3 127000-03if(init1.eq.ESMF_INIT_CREATED.and.&init2.eq.ESMF_INIT_CREATED)then! Call into the C++ interface to determine equalitycall c_ESMC_HConfigEqual(HConfig1,HConfig2,isEqual)! Translate from ESMF logical to Fortran logicalESMF_HConfigEQ=isEqualendif end function ESMF_HConfigEQ