ESMF_GeomValidate Subroutine

public subroutine ESMF_GeomValidate(geom, rc)

Arguments

Type IntentOptional Attributes Name
type(ESMF_Geom), intent(in) :: geom
integer, intent(out), optional :: rc

Calls

proc~~esmf_geomvalidate~~CallsGraph proc~esmf_geomvalidate ESMF_GeomValidate proc~esmf_geomgetinit ESMF_GeomGetInit proc~esmf_geomvalidate->proc~esmf_geomgetinit proc~esmf_gridvalidate ESMF_GridValidate proc~esmf_geomvalidate->proc~esmf_gridvalidate proc~esmf_imerr ESMF_IMErr proc~esmf_geomvalidate->proc~esmf_imerr proc~esmf_locstreamvalidate ESMF_LocStreamValidate proc~esmf_geomvalidate->proc~esmf_locstreamvalidate proc~esmf_logfounderror ESMF_LogFoundError proc~esmf_geomvalidate->proc~esmf_logfounderror proc~esmf_xgridvalidate ESMF_XGridValidate proc~esmf_geomvalidate->proc~esmf_xgridvalidate proc~esmf_gridvalidate->proc~esmf_imerr proc~esmf_gridvalidate->proc~esmf_logfounderror c_esmc_gridvalidate c_esmc_gridvalidate proc~esmf_gridvalidate->c_esmc_gridvalidate proc~esmf_gridgetinit ESMF_GridGetInit proc~esmf_gridvalidate->proc~esmf_gridgetinit proc~esmf_imerr->proc~esmf_logfounderror proc~esmf_initcheckdeep ESMF_InitCheckDeep proc~esmf_imerr->proc~esmf_initcheckdeep proc~esmf_locstreamvalidate->proc~esmf_imerr proc~esmf_locstreamgetinit ESMF_LocStreamGetInit proc~esmf_locstreamvalidate->proc~esmf_locstreamgetinit esmf_breakpoint esmf_breakpoint proc~esmf_logfounderror->esmf_breakpoint proc~esmf_logrc2msg ESMF_LogRc2Msg proc~esmf_logfounderror->proc~esmf_logrc2msg proc~esmf_logwrite ESMF_LogWrite proc~esmf_logfounderror->proc~esmf_logwrite proc~esmf_xgridvalidate->proc~esmf_imerr proc~esmf_xgridvalidate->proc~esmf_logfounderror proc~esmf_basegetstatus ESMF_BaseGetStatus proc~esmf_xgridvalidate->proc~esmf_basegetstatus proc~esmf_logseterror ESMF_LogSetError proc~esmf_xgridvalidate->proc~esmf_logseterror proc~esmf_xgridgetinit ESMF_XGridGetInit proc~esmf_xgridvalidate->proc~esmf_xgridgetinit proc~esmf_basegetstatus->proc~esmf_logfounderror c_esmc_basegetstatus c_esmc_basegetstatus proc~esmf_basegetstatus->c_esmc_basegetstatus c_esmc_loggeterrormsg c_esmc_loggeterrormsg proc~esmf_logrc2msg->c_esmc_loggeterrormsg proc~esmf_logseterror->esmf_breakpoint proc~esmf_logseterror->proc~esmf_logrc2msg proc~esmf_logseterror->proc~esmf_logwrite c_esmc_vmwtime c_esmc_vmwtime proc~esmf_logwrite->c_esmc_vmwtime proc~esmf_logclose ESMF_LogClose proc~esmf_logwrite->proc~esmf_logclose proc~esmf_logflush ESMF_LogFlush proc~esmf_logwrite->proc~esmf_logflush proc~esmf_logopenfile ESMF_LogOpenFile proc~esmf_logwrite->proc~esmf_logopenfile proc~esmf_utiliounitflush ESMF_UtilIOUnitFlush proc~esmf_logwrite->proc~esmf_utiliounitflush proc~esmf_utilstring2array ESMF_UtilString2Array proc~esmf_logwrite->proc~esmf_utilstring2array proc~esmf_logclose->proc~esmf_logflush proc~esmf_logflush->proc~esmf_utiliounitflush proc~esmf_utilarray2string ESMF_UtilArray2String proc~esmf_logflush->proc~esmf_utilarray2string proc~esmf_logopenfile->proc~esmf_utiliounitflush proc~esmf_utiliounitget ESMF_UtilIOUnitGet proc~esmf_logopenfile->proc~esmf_utiliounitget

Called by

proc~~esmf_geomvalidate~~CalledByGraph proc~esmf_geomvalidate ESMF_GeomValidate proc~esmf_fieldvalidate ESMF_FieldValidate proc~esmf_fieldvalidate->proc~esmf_geomvalidate proc~esmf_statevalidate ESMF_StateValidate proc~esmf_statevalidate->proc~esmf_fieldvalidate proc~test7d4_generic test7d4_generic proc~test7d4_generic->proc~esmf_fieldvalidate proc~test_mesh_create_gt_1localde test_mesh_create_gt_1localde proc~test_mesh_create_gt_1localde->proc~esmf_fieldvalidate program~esmf_meshutest ESMF_MeshUTest program~esmf_meshutest->proc~esmf_fieldvalidate program~esmf_meshutest->proc~test_mesh_create_gt_1localde program~esmf_statereconcileutest ESMF_StateReconcileUTest program~esmf_statereconcileutest->proc~esmf_statevalidate

Source Code

  subroutine ESMF_GeomValidate(geom, rc)
!
! !ARGUMENTS:
    type(ESMF_Geom), intent(in)              :: geom
    integer,             intent(out),  optional  :: rc
!
!
! !DESCRIPTION:
!      Validates that the {\tt Geom} is internally consistent.
!
!     The arguments are:
!     \begin{description}
!     \item[geom]
!          Specified {\tt ESMF\_Geom} object.
!     \item[{[rc]}]
!          Return code; equals {\tt ESMF\_SUCCESS} if there are no errors.
!     \end{description}
!
!EOPI
!------------------------------------------------------------------------------
    integer :: localrc
    type(ESMF_GeomClass),pointer :: gbcp

    ! Initialize return code; assume failure until success is certain
    if (present(rc)) rc = ESMF_RC_NOT_IMPL

    ! Check init status of arguments
    ESMF_INIT_CHECK_DEEP_SHORT(ESMF_GeomGetInit, geom, rc)

    ! Get GeomClass
    gbcp=>geom%gbcp

    ! Get info depending on type
    select case(gbcp%type%type)

       case (ESMF_GEOMTYPE_GRID%type) ! Grid
         call ESMF_GridValidate(grid=gbcp%grid, rc=localrc)
          if (ESMF_LogFoundError(localrc, &
                                 ESMF_ERR_PASSTHRU, &
                                 ESMF_CONTEXT, rcToReturn=rc)) return

       case (ESMF_GEOMTYPE_MESH%type) ! Mesh
         !call ESMF_MeshValidate(mesh=gbcp%mesh, rc=localrc)
         ! if (ESMF_LogFoundError(localrc, &
         !                        ESMF_ERR_PASSTHRU, &
         !                        ESMF_CONTEXT, rcToReturn=rc)) return

       case (ESMF_GEOMTYPE_LOCSTREAM%type) ! LocStream
          call ESMF_LocStreamValidate(locstream=gbcp%locstream, rc=localrc)
          if (ESMF_LogFoundError(localrc, &
                                 ESMF_ERR_PASSTHRU, &
                                 ESMF_CONTEXT, rcToReturn=rc)) return

       case (ESMF_GEOMTYPE_XGRID%type) ! XGrid
           call ESMF_XGridValidate(xgrid=gbcp%xgrid, rc=localrc)
          if (ESMF_LogFoundError(localrc, &
                                 ESMF_ERR_PASSTHRU, &
                                 ESMF_CONTEXT, rcToReturn=rc)) return

       case default
         if (ESMF_LogFoundError(ESMF_RC_ARG_VALUE, &
                               msg=" Bad type value", &
                               ESMF_CONTEXT, rcToReturn=rc)) return
    end select


    ! Set return value
    if (present(rc)) rc = ESMF_SUCCESS

  end subroutine ESMF_GeomValidate