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
impure elemental function ESMF_XGridEQ(xgrid1,xgrid2)! ! !RETURN VALUE:logical::ESMF_XGridEQ! !ARGUMENTS:type(ESMF_XGrid),intent(in)::xgrid1type(ESMF_XGrid),intent(in)::xgrid2! !DESCRIPTION:! Test if both {\tt xgrid1} and {\tt xgrid2} alias the same ESMF XGrid ! object.!!EOPI!-------------------------------------------------------------------------------ESMF_INIT_TYPExginit1,xginit2integer::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 inputsxginit1=ESMF_XGridGetInit(xgrid1)xginit2=ESMF_XGridGetInit(xgrid2)! TODO: this line must remain split in two for SunOS f90 8.3 127000-03if(xginit1.eq.ESMF_INIT_CREATED.and.&xginit2.eq.ESMF_INIT_CREATED)thenESMF_XGridEQ=associated(xgrid1%xgtypep,xgrid2%xgtypep)elseESMF_XGridEQ=ESMF_FALSEendif end function ESMF_XGridEQ