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 DBIELB (NDB, OPTION, NELBS, NELBE, & IDELB, NUMELB, NUMLNK, NUMATR, & A, KLINK, KATRIB, *) C======================================================================= C --*** DBIELB *** (EXOLIB) Read database element blocks C -- Written by Amy Gilkey - revised 10/14/87 C -- C --DBIELB reads the element block information from the database. C --An error message is displayed if the end of file is read. C -- C --The dynamic memory arrays LINK and ATRIB must be reserved C --if the connectivity and attributes are to be stored. These arrays C --will be expanded by this routine to hold the new data. C -- C --Parameters: C -- NDB - IN - the database file C -- OPTION - IN - ' ' to not store, '*' to store all, else store options: C -- 'H' to store all header information C -- 'I' to store block IDs C -- 'C' to store connectivity (+ NUMLNK + NUMELB) C -- 'A' to store attributes (+ NUMATR + NUMELB) C -- NELBS, NELBE - IN - the number of first and last element blocks C -- to read C -- IDELB - OUT - the element block IDs for each block (if OPTION) C -- NUMELB - OUT - the number of elements in each block (if OPTION) C -- NUMLNK - OUT - the number of nodes per element in each block C -- (if OPTION) C -- NUMATR - OUT - the number of attributes in each block (if OPTION) C -- A - IN/OUT - the dynamic memory base array C -- KLINK - OUT - pointer to the connectivity for each block (if OPTION) C -- KATRIB - OUT - pointer to the attributes for each block (if OPTION) C -- * - return statement if end of file or read error C -- C --Database must be positioned at start of element block information C --upon entry; upon exit at end of element block information. INTEGER NDB CHARACTER*(*) OPTION INTEGER NELBS, NELBE INTEGER IDELB(*) INTEGER NUMELB(*) INTEGER NUMLNK(*) INTEGER NUMATR(*) DIMENSION A(*) INTEGER KLINK, KATRIB CHARACTER*80 ERRMSG IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'C') .GT. 0)) THEN CALL MDFIND ('LINK', KLINK, IELNK) ELSE KLINK = 0 END IF IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'A') .GT. 0)) THEN CALL MDFIND ('ATRIB', KATRIB, IEATR) ELSE KATRIB = 0 END IF CALL MDSTAT (NERR, MEM) IF (NERR .GT. 0) GOTO 110 DO 100 NELB = NELBS, NELBE IELB = NELB-NELBS+1 READ (NDB, END=120, ERR=120, IOSTAT=IERR) & ID, NEL, NLNK, NATR IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'H') .GT. 0)) THEN IDELB(IELB) = ID NUMELB(IELB) = NEL NUMLNK(IELB) = NLNK NUMATR(IELB) = NATR END IF IF (INDEX (OPTION, 'I') .GT. 0) THEN IDELB(IELB) = ID END IF IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'C') .GT. 0)) THEN NUMELB(IELB) = NEL NUMLNK(IELB) = NLNK ISLNK = IELNK + 1 IELNK = IELNK + NLNK * NEL CALL MDLONG ('LINK', KLINK, IELNK) END IF IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'A') .GT. 0)) THEN NUMELB(IELB) = NEL NUMATR(IELB) = NATR ISATR = IEATR + 1 IEATR = IEATR + NATR * NEL CALL MDLONG ('ATRIB', KATRIB, IEATR) END IF CALL MDSTAT (NERR, MEM) IF (NERR .GT. 0) GOTO 110 CALL DBIEB1 (NDB, OPTION, NELB, & NEL, NLNK, NATR, & A(KLINK+ISLNK-1), A(KATRIB+ISATR-1), $ MAX(NATR,1), MAX(NLNK,1), *130) 100 CONTINUE 110 CONTINUE RETURN 120 CONTINUE WRITE (ERRMSG, '(A, I8)', IOSTAT=IDUM) & 'ELEMENT BLOCK SIZING PARAMETERS for BLOCK', NELB CALL DBERR (IERR, ERRMSG) 130 CONTINUE RETURN 1 END