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.

72 lines
2.5 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 RDELB (NTXT, IELB, IDELB, NUMELB, NUMLNK, NUMATR,
& NAMELB, A, KLINK, KATRIB, *)
C=======================================================================
C --*** RDELB *** (TXTEXO) Read database element block
C -- Written by Amy Gilkey - revised 02/27/86
C --
C --RDELB reads the element block information from the text file.
C --Some dynamic dimensioning is done.
C --An error message is displayed if the end of file is read.
C --
C --Parameters:
C -- NTXT - IN - the text file
C -- IELB - IN - the element block number
C -- IDELB - IN - the id for this block
C -- NUMELB - IN - the number of elements in this block
C -- NUMLNK - IN - the number of nodes per element in this block
C -- NUMATR - IN - the number of attributes in this block
C -- A - IN - the dynamic memory base array
C -- KLINK - IN - pointer to the element connectivity for this block
C -- KATRIB - IN - pointer to the attributes for this block
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.
include 'exodusII.inc'
DIMENSION A(*)
CHARACTER*(MXSTLN) NAMELB
CHARACTER*32 STRA
NAMELB = ' '
READ (NTXT, *, END=110, ERR=110)
READ (NTXT, *, END=110, ERR=110) IDELB, NUMELB, NAMELB
C ... Strip everything in namelb from first space to end
IEX = index(namelb, " ")
if (iex .gt. 0) then
namelb(iex:) = " "
end if
READ (NTXT, *, END=110, ERR=110) NUMLNK, NUMATR
IECON = NUMLNK * NUMELB
CALL MDLONG ('LINK', KLINK, IECON)
IEATR = NUMATR * NUMELB
CALL MDLONG ('ATRIB', KATRIB, IEATR)
CALL MDSTAT (NERR, MEM)
IF (NERR .GT. 0) GOTO 100
CALL RDEB1 (NTXT, IELB, NUMELB, NUMLNK, NUMATR,
& A(KLINK), A(KATRIB), max(1,numatr), *120)
100 CONTINUE
RETURN
110 CONTINUE
CALL INTSTR (1, 0, IELB, STRA, LSTRA)
CALL PRTERR ('FATAL',
& 'Reading ELEMENT BLOCK SIZING PARAMETERS for block '
& // STRA(:LSTRA))
120 CONTINUE
RETURN 1
END