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.

97 lines
2.9 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 -*- Mode: fortran -*-
SUBROUTINE RDSPLN (DOUBLE, STORE, NDB, RDTHET, SLLFT, SLRGT, NSPL,
* RSA, ZSA, RSB, ZSB)
C ... If only single spline, then RSB is Thickness
LOGICAL DOUBLE, STORE
REAL RSA(*), ZSA(*), RSB(*), ZSB(*)
INTEGER NSPL(2)
REAL SLLFT(2), SLRGT(2)
INTEGER NDB
LOGICAL RDTHET, MATSTR
PARAMETER (BINGO = 1.0E38)
PARAMETER (MXFLD = 4)
REAL RVAL(MXFLD)
INTEGER KVAL(MXFLD), IVAL(MXFLD)
CHARACTER*8 CVAL(MXFLD)
REWIND (NDB)
RDTHET = .FALSE.
IPTA = 0
IPTB = 0
SLLFT(1) = BINGO
SLRGT(1) = BINGO
SLLFT(2) = BINGO
SLRGT(2) = BINGO
ISPL = 1
10 CONTINUE
CALL FREFLD ( NDB, 0, 'AUTO', MXFLD, IERR,
* NFLD, KVAL, CVAL, IVAL, RVAL)
IF (IERR .EQ. 0) THEN
IF (KVAL(1) .EQ. 0) THEN
IF (MATSTR(CVAL(1), 'LEFT', 1)) THEN
if (store) SLLFT(ISPL) = RVAL(2)
ELSE IF (MATSTR(CVAL(1), 'RIGHT', 1)) THEN
if (store) SLRGT(ISPL) = RVAL(2)
ELSE IF (MATSTR(CVAL(1), 'ANGULAR', 1)) THEN
RDTHET = .TRUE.
ELSE IF (MATSTR(CVAL(1), 'TOP', 1) .OR.
& MATSTR(CVAL(1), 'FRONT', 1)) THEN
IF (.NOT. STORE) DOUBLE = .TRUE.
ISPL = 1
ELSE IF (MATSTR(CVAL(1), 'BOTTOM', 1) .OR.
& MATSTR(CVAL(1), 'BACK', 1)) THEN
IF (.NOT. STORE) DOUBLE = .TRUE.
ISPL = 2
else if (matstr(cval(1), 'slope', 1)) then
if (matstr(cval(2), 'top', 1) .or.
& matstr(cval(2), 'front', 1)) then
if (store) then
sllft(1) = rval(3)
sllft(2) = rval(4)
end if
else if (matstr(cval(2), 'back', 1) .or.
& matstr(cval(2), 'bottom', 1)) then
if (store) then
slrgt(1) = rval(3)
slrgt(2) = rval(4)
end if
end if
END IF
ELSE IF (NFLD .GE. 2) THEN
IF (ISPL .EQ. 1) THEN
IPTA = IPTA + 1
IF (STORE) THEN
RSA(IPTA) = RVAL(1)
ZSA(IPTA) = RVAL(2)
IF (.NOT. DOUBLE) RSB(IPTA) = RVAL(3)
END IF
ELSE
IPTB = IPTB + 1
IF (STORE) THEN
RSB(IPTB) = RVAL(1)
ZSB(IPTB) = RVAL(2)
END IF
END IF
END IF
GO TO 10
END IF
IF (.NOT. STORE) THEN
NSPL(1) = IPTA
NSPL(2) = IPTB
END IF
RETURN
END