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
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
|