Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

136 lines
4.8 KiB

2 years ago
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, IA, KLINK, KATRIB, NAMELB, EBNAME,
$ LPTR, NAMLEN, *)
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 - IN - the number of the first element block to read
C -- NELBE - IN - the number of the last element block to read
C -- IDELB - OUT - the element block IDs for each block
C -- NUMELB - OUT - the number of elements in each block
C -- NUMLNK - OUT - the number of nodes per element in each block
C -- NUMATR - OUT - the number of attributes in each block
C -- A - I/O - the dynamic memory base array for REALS
C -- IA - I/O - the dynamic memory base array for INTEGERS
C -- KLINK - OUT - pointer to the connectivity for each block
C -- KATRIB - OUT - pointer to the attributes for each block
C -- NAMELB - OUT - the type of element in each block
C -- LPTR - OUT - pointers to connectivity for each block
C -- * - OUT - return statement if end of file or read error
include 'exodusII.inc'
INTEGER NDB
CHARACTER*(*) OPTION
INTEGER NELBS, NELBE
INTEGER IDELB(*)
INTEGER NUMELB(*)
INTEGER NUMLNK(*)
INTEGER NUMATR(*)
DIMENSION A(*), IA(*)
INTEGER KLINK, KATRIB
CHARACTER*(MXSTLN) NAMELB(*)
CHARACTER*(NAMLEN) EBNAME(*)
INTEGER LPTR(*)
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
IESAV = IELNK
IASAV = IEATR
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'C') .GT. 0)
& .OR. (INDEX (OPTION, 'A') .GT. 0)) THEN
DO 90 NELB = NELBS, NELBE
IELB = NELB-NELBS+1
call exgelb(ndb, idelb(ielb), namelb(ielb), nel, nlnk,
& natr, ierr)
CALL EXUPCS (NAMELB(IELB))
CALL PCKSTR (1, NAMELB(IELB))
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'H') .GT. 0)) THEN
NUMELB(IELB) = NEL
NUMLNK(IELB) = NLNK
NUMATR(IELB) = NATR
END IF
IELNK = IELNK + NLNK * NEL
IEATR = IEATR + NATR * NEL
90 CONTINUE
CALL MDLONG ('LINK', KLINK, IELNK)
CALL MDLONG ('ATRIB', KATRIB, IEATR)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 110
END IF
IELNK = IESAV
IEATR = IASAV
DO 100 NELB = NELBS, NELBE
IELB = NELB-NELBS+1
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'C') .GT. 0)) THEN
ISLNK = IELNK + 1
IELNK = IELNK + NUMLNK(IELB) * NUMELB(IELB)
END IF
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'A') .GT. 0)) THEN
ISATR = IEATR + 1
IEATR = IEATR + NUMATR(IELB) * NUMELB(IELB)
END IF
if (numelb(ielb) .gt. 0) then
CALL DBIEBI (NDB, OPTION, IDELB(IELB), NEL, NLNK, NATR,
& IA(KLINK+ISLNK-1), A(KATRIB+ISATR-1),
& MAX(NATR,1), MAX(NLNK,1), *130)
end if
100 CONTINUE
C ... Read element block names (if they exist)
CALL EXGNAMS(NDB, EXEBLK, NELBE, ebname, ierr)
C Store the first pointers for each element block link array
INC = 0
ISIZE = 0
DO 105 I = NELBS, NELBE
IELB = I-NELBS+1
INC = ISIZE + 1
ISIZE = ISIZE + NUMELB(IELB)*NUMLNK(IELB)
LPTR(I) = KLINK + INC - 1
105 CONTINUE
110 CONTINUE
RETURN
130 CONTINUE
RETURN 1
END