C Copyright(C) 1999-2020 National Technology & Engineering Solutions C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with C NTESS, the U.S. Government retains certain rights in this software. C C See packages/seacas/LICENSE for details C======================================================================= SUBROUTINE DBITIM (NDB, OPTION, EXODUS, & NVARNP, NELBLK, NVAREL, ISEVOK, & NSTEPS, NSTEPW, A, KTIMES, KWHOLE, *) C======================================================================= C --*** DBITIM *** (EXOLIB) Read database time step times C -- Written by Amy Gilkey - revised 11/11/87 C -- C --DBITIM reads all time steps of the database, storing the time for C --each step in dynamic memory. It also sets the number of time steps. C --If there is a dynamic memory problem, the routine returns immediately C --without issuing an error message. If there is a read error, a C --warning is printed and the step with the error is ignored. C -- C --Parameters: C -- NDB - IN - the database number C -- OPTION - IN - ' ' to not store, '*' to store all, else store options: C -- 'W' to store whole times only C -- 'H' to store history times only C -- EXODUS - IN - true iff this is an EXODUS file C -- NVARNP - IN - the number of nodal variables C -- NELBLK - IN - the number of element blocks C -- NVAREL - IN - the number of element variables C -- ISEVOK - IN - the element block variable truth table; C -- variable i of block j exists iff ISEVOK(j,i) C -- NSTEPS - OUT - the number of database time steps C -- NSTEPW - OUT - the number of whole (versus history) database time steps C -- A - IN/OUT - the dynamic memory base array C -- KTIMES - OUT - the dynamic memory index of TIMES (if OPTION) C -- KWHOLE - OUT - the dynamic memory index of WHOTIM (if OPTION); C -- WHOTIM(i) is true iff TIMES(i) is a whole (versus history) time step C -- * - return statement if error encountered, message is printed C -- C --Database must be positioned in front of first time step upon entry; C --upon exit positioned at end of file. include 'exodusII.inc' INTEGER NDB CHARACTER*(*) OPTION LOGICAL EXODUS INTEGER NVARNP, NELBLK, NVAREL C --NOTE: ISEVOK is doubly-dimensioned array (NELBLK,NVAREL) LOGICAL ISEVOK(*) INTEGER NSTEPS, NSTEPW REAL A(*) INTEGER KTIMES INTEGER KWHOLE CHARACTER*8 CDUM LOGICAL STOWHO, STOHIS STOWHO = ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'W') .GT. 0)) STOHIS = ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'H') .GT. 0)) IF (.NOT. EXODUS) GOTO 140 call exinq(ndb, EXTIMS, nsteps, rdum, cdum, ierr) nstepw = nsteps C --Reserve memory for step times if (nsteps .le. 0) then EXODUS = .FALSE. goto 140 end if CALL MDRSRV ('TIMES', KTIMES, nsteps) IF (STOWHO .AND. STOHIS) THEN CALL MDRSRV ('WHOTIM', KWHOLE, nsteps) END IF CALL MDSTAT (NERR, MEM) IF (NERR .GT. 0) GOTO 150 WRITE (*, 10000) 'Please wait while the step times are read in' C --Set NRECST = the number of database records in a whole time step IF (.TRUE.) THEN C --Read step time call exgatm(ndb, a(ktimes), ierr) C --Store step time after time step read correctly CALL INILOG (nsteps, .TRUE., A(KWHOLE)) END IF 140 CONTINUE 150 CONTINUE RETURN 10000 FORMAT (/, 1X, A) END