ESMF_ClockAdvance Subroutine

public subroutine ESMF_ClockAdvance(clock, keywordEnforcer, timeStep, ringingAlarmList, ringingAlarmCount, rc)

Arguments

Type IntentOptional Attributes Name
type(ESMF_Clock), intent(inout) :: clock
type(ESMF_KeywordEnforcer), optional :: keywordEnforcer
type(ESMF_TimeInterval), intent(in), optional :: timeStep
type(ESMF_Alarm), intent(out), optional :: ringingAlarmList(:)
integer, intent(out), optional :: ringingAlarmCount
integer, intent(out), optional :: rc

Calls

proc~~esmf_clockadvance~~CallsGraph proc~esmf_clockadvance ESMF_ClockAdvance c_esmc_clockadvance0 c_esmc_clockadvance0 proc~esmf_clockadvance->c_esmc_clockadvance0 c_esmc_clockadvance1 c_esmc_clockadvance1 proc~esmf_clockadvance->c_esmc_clockadvance1 c_esmc_clockadvance2 c_esmc_clockadvance2 proc~esmf_clockadvance->c_esmc_clockadvance2 proc~esmf_alarmsetinitcreated ESMF_AlarmSetInitCreated proc~esmf_clockadvance->proc~esmf_alarmsetinitcreated proc~esmf_alarmsetthis ESMF_AlarmSetThis proc~esmf_clockadvance->proc~esmf_alarmsetthis proc~esmf_clockgetinit ESMF_ClockGetInit proc~esmf_clockadvance->proc~esmf_clockgetinit proc~esmf_imerr ESMF_IMErr proc~esmf_clockadvance->proc~esmf_imerr proc~esmf_imerrs ESMF_IMErrS proc~esmf_clockadvance->proc~esmf_imerrs proc~esmf_logfounderror ESMF_LogFoundError proc~esmf_clockadvance->proc~esmf_logfounderror proc~esmf_timeintervalgetinit ESMF_TimeIntervalGetInit proc~esmf_clockadvance->proc~esmf_timeintervalgetinit proc~esmf_imerr->proc~esmf_logfounderror proc~esmf_initcheckdeep ESMF_InitCheckDeep proc~esmf_imerr->proc~esmf_initcheckdeep proc~esmf_imerrs->proc~esmf_logfounderror proc~esmf_initcheckshallow ESMF_InitCheckShallow proc~esmf_imerrs->proc~esmf_initcheckshallow 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 c_esmc_loggeterrormsg c_esmc_loggeterrormsg proc~esmf_logrc2msg->c_esmc_loggeterrormsg 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_clockadvance~~CalledByGraph proc~esmf_clockadvance ESMF_ClockAdvance proc~get_sync_alarms get_sync_alarms proc~get_sync_alarms->proc~esmf_clockadvance proc~nuopc_runsequencectrl NUOPC_RunSequenceCtrl proc~nuopc_runsequencectrl->proc~esmf_clockadvance proc~nuopc_runsequencectrl->proc~nuopc_runsequencectrl proc~nuopc_runsequenceiterate NUOPC_RunSequenceIterate proc~nuopc_runsequenceiterate->proc~esmf_clockadvance proc~nuopc_runsequenceiterate->proc~nuopc_runsequencectrl proc~routine_run routine_Run proc~routine_run->proc~esmf_clockadvance program~concurrentcomponent ConcurrentComponent program~concurrentcomponent->proc~esmf_clockadvance program~esmf_alarmex ESMF_AlarmEx program~esmf_alarmex->proc~esmf_clockadvance program~esmf_appmainex ESMF_AppMainEx program~esmf_appmainex->proc~esmf_clockadvance program~esmf_appmainex~2 ESMF_AppMainEx program~esmf_appmainex~2->proc~esmf_clockadvance program~esmf_appmainex~3 ESMF_AppMainEx program~esmf_appmainex~3->proc~esmf_clockadvance program~esmf_clockex ESMF_ClockEx program~esmf_clockex->proc~esmf_clockadvance program~esmf_concurrentensemblestest ESMF_ConcurrentEnsembleSTest program~esmf_concurrentensemblestest->proc~esmf_clockadvance program~esmf_fieldbundlelsredistarb2arbstest ESMF_FieldBundleLSRedistArb2ArbSTest program~esmf_fieldbundlelsredistarb2arbstest->proc~esmf_clockadvance program~esmf_fieldbundlelsredistarb2arbungrddimstest ESMF_FieldBundleLSRedistArb2ArbUngrdDimSTest program~esmf_fieldbundlelsredistarb2arbungrddimstest->proc~esmf_clockadvance program~esmf_fieldlsredistarb2arbstest ESMF_FieldLSRedistArb2ArbSTest program~esmf_fieldlsredistarb2arbstest->proc~esmf_clockadvance program~esmf_fieldlsredistarb2arbungrddimstest ESMF_FieldLSRedistArb2ArbUngrdDimSTest program~esmf_fieldlsredistarb2arbungrddimstest->proc~esmf_clockadvance program~esmf_fieldlssmmstest ESMF_FieldLSSMMSTest program~esmf_fieldlssmmstest->proc~esmf_clockadvance program~esmf_fieldmeshsmmstest ESMF_FieldMeshSMMSTest program~esmf_fieldmeshsmmstest->proc~esmf_clockadvance program~esmf_fieldregridlsstest ESMF_FieldRegridLSSTest program~esmf_fieldregridlsstest->proc~esmf_clockadvance program~esmf_fieldregridstest ESMF_FieldRegridSTest program~esmf_fieldregridstest->proc~esmf_clockadvance program~esmf_fieldregridstest~2 ESMF_FieldRegridSTest program~esmf_fieldregridstest~2->proc~esmf_clockadvance program~esmf_fieldregridstest~3 ESMF_FieldRegridSTest program~esmf_fieldregridstest~3->proc~esmf_clockadvance program~esmf_sequentialensemblestest ESMF_SequentialEnsembleSTest program~esmf_sequentialensemblestest->proc~esmf_clockadvance program~fieldconcurrentcomponent FieldConcurrentComponent program~fieldconcurrentcomponent->proc~esmf_clockadvance program~fieldregridconserv FieldRegridConserv program~fieldregridconserv->proc~esmf_clockadvance program~fieldregridmulti FieldRegridMulti program~fieldregridmulti->proc~esmf_clockadvance program~fieldregridorder FieldRegridOrder program~fieldregridorder->proc~esmf_clockadvance program~mappersimpletwoconcurrentcomps MapperSimpleTwoConcurrentComps program~mappersimpletwoconcurrentcomps->proc~esmf_clockadvance program~mappertwoconcurrentcomps MapperTwoConcurrentComps program~mappertwoconcurrentcomps->proc~esmf_clockadvance program~mappertwoconcurrentcomps->proc~get_sync_alarms proc~executerunsequence ExecuteRunSequence proc~executerunsequence->proc~nuopc_runsequenceiterate

Source Code

      subroutine ESMF_ClockAdvance(clock, keywordEnforcer, &
        timeStep, ringingAlarmList, ringingAlarmCount, rc)

! !ARGUMENTS:
      type(ESMF_Clock),        intent(inout)         :: clock
      type(ESMF_KeywordEnforcer), optional:: keywordEnforcer ! must use keywords below
      type(ESMF_TimeInterval), intent(in),  optional :: timeStep
      type(ESMF_Alarm),        intent(out), optional :: ringingAlarmList(:)
      integer,                 intent(out), optional :: ringingAlarmCount
      integer,                 intent(out), optional :: rc
!
!
! !STATUS:
! \begin{itemize}
! \item\apiStatusCompatibleVersion{5.2.0r}
! \end{itemize}
!
! !DESCRIPTION:
!     \begin{sloppypar}
!     Advances the {\tt clock}'s current time by one time step:  either the
!     {\tt clock}'s, or the passed-in {\tt timeStep} (see below).  When the
!     {\tt clock} is in {\tt ESMF\_DIRECTION\_FORWARD} (default), this method
!     adds the {\tt timeStep} to the {\tt clock}'s current time.
!     In {\tt ESMF\_DIRECTION\_REVERSE}, {\tt timeStep} is subtracted from the
!     current time.  In either case, {\tt timeStep} can be positive or negative.
!     See the "direction" argument in method {\tt ESMF\_ClockSet()}.
!     {\tt ESMF\_ClockAdvance()} optionally returns a list and number of ringing
!     {\tt ESMF\_Alarm}s.  See also method {\tt ESMF\_ClockGetRingingAlarms()}.
!     \end{sloppypar}
!
!     The arguments are:
!     \begin{description}
!     \item[clock]
!          The object instance to advance.
!     \item[{[timeStep]}]
!          Time step is performed with given timeStep, instead of
!          the {\tt ESMF\_Clock}'s.  Does not replace the {\tt ESMF\_Clock}'s
!          timeStep; use {\tt ESMF\_ClockSet(clock, timeStep, ...)} for
!          this purpose.  Supports applications with variable time steps.
!          timeStep can be positive or negative.
!     \item[{[ringingAlarmList]}]
!          Returns the array of alarms that are ringing after the
!          time step.
!     \item[{[ringingAlarmCount]}]
!          The number of alarms ringing after the time step.
!     \item[{[rc]}]
!          Return code; equals {\tt ESMF\_SUCCESS} if there are no errors.
!     \end{description}
!
!EOP
! !REQUIREMENTS:
!     TMG3.4.1


      ! initialize list size to zero for not-present list
      integer :: sizeofRingingAlarmList,i
      type(ESMF_Pointer), allocatable :: ringingAlarmPtrList(:)
      integer :: localrc                        ! local return code

      ! Assume failure until success
      if (present(rc)) rc = ESMF_RC_NOT_IMPL
      localrc = ESMF_RC_NOT_IMPL

      ! check inputs
      ESMF_INIT_CHECK_DEEP(ESMF_ClockGetInit,clock,rc)
      ESMF_INIT_CHECK_SHALLOW(ESMF_TimeIntervalGetInit,timeStep,rc)

      sizeofRingingAlarmList = 0

      ! get size of given ringing alarm list for C++ validation
      if (present(ringingAlarmList)) then
        sizeofRingingAlarmList = size(ringingAlarmList)

        ! for Init Macros
        allocate(ringingAlarmPtrList(sizeofRingingAlarmList))
      end if

      ! invoke C to C++ entry point

      if (present(ringingAlarmList) .and. sizeofRingingAlarmList > 1) then
        ! pass address of 2nd element for C++ to calculate array step size
        call c_ESMC_ClockAdvance2(clock, timeStep, &
                     ringingAlarmPtrList(1), ringingAlarmPtrList(2), &
                     sizeofRingingAlarmList, ringingAlarmCount, localrc)
        if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, &
          ESMF_CONTEXT, rcToReturn=rc)) then
          ! Not bail out until deallocation
          write(*,*)"c_ESMC_ClockAdvance2 fails"
        endif
      else if (sizeofRingingAlarmList == 1) then
        ! array has only one element
        call c_ESMC_ClockAdvance1(clock, timeStep, ringingAlarmPtrList(1), &
                        sizeofRingingAlarmList, ringingAlarmCount, localrc)
        ! Not bail out until deallocation
        if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, &
          ESMF_CONTEXT, rcToReturn=rc)) then
          ! Not bail out until deallocation
          write(*,*)"c_ESMC_ClockAdvance1 fails"
        endif
      else
        ! array is not present
        call c_ESMC_ClockAdvance0(clock, timeStep, &
                    sizeofRingingAlarmList, ringingAlarmCount, localrc)
        if (ESMF_LogFoundError(localrc, ESMF_ERR_PASSTHRU, &
          ESMF_CONTEXT, rcToReturn=rc)) then
          ! Not bail out until deallocation
          write(*,*)"c_ESMC_ClockAdvance0 fails"
        endif
      endif

      ! post-process ringing alarm list
      if (present(ringingAlarmList)) then
         do i=1,sizeofRingingAlarmList
            call ESMF_AlarmSetThis(ringingAlarmList(i),ringingAlarmPtrList(i))
            ! mark output as successfully initialized
            call ESMF_AlarmSetInitCreated(ringingAlarmList(i))
         enddo

        ! Get rid of list
        deallocate(ringingAlarmPtrList)
     end if

     ! Return success
     if (present(rc)) rc = localrc

     end subroutine ESMF_ClockAdvance