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.

165 lines
4.6 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 ALICMD (INLINE, INTYP, CFIELD, IFIELD, NAMES, *)
C=======================================================================
C --*** ALICMD *** (ALGEBRA) Perform ALIAS command
C -- Written by Amy Gilkey - revised 12/02/87
C --
C --ALICMD processes the input ALIAS command. It adds the alias and
C --the equivalent variables to the /ALIAS../ arrays.
C --
C --Parameters:
C -- INLINE - IN/OUT - the parsed input lines for the log file
C -- INTYP - IN - the field types
C -- CFIELD - IN - the character fields
C -- IFIELD - IN - the integer fields
C -- NAMES - IN - the names of the global, nodal, and element variables
C -- * - return statement if command not executed
C --
C --Common Variables:
C -- Sets NUMALI, NAMALI, NIXALI, IXALI of /ALIAS../
C -- Uses NVARHI, NVARGL, NVARNP, NVAREL of /DBNUMS/
include 'exodusII.inc'
include 'ag_namlen.blk'
include 'ag_alias.blk'
include 'ag_dbnums.blk'
CHARACTER*(*) INLINE
INTEGER INTYP(*)
CHARACTER*(*) CFIELD(*)
INTEGER IFIELD(*)
CHARACTER*(namlen) NAMES(*)
LOGICAL FFEXST, FFNUMB
CHARACTER*(maxnam) NAME
CHARACTER TYPNAM, TYP
c DATA NUMALI / 0 /
NUMALI = 0
IF (.NOT. FFEXST (1, INTYP)) THEN
CALL PRTERR ('CMDERR', 'No options on ALIAS command')
GOTO 130
END IF
IF (NUMALI .GE. MAXALI) THEN
CALL PRTERR ('CMDERR', 'ALIAS table full, command ignored')
GOTO 130
END IF
NVNAMS = NVARHI + NVARGL + NVARNP + NVAREL
C --Get the tensor name
IFLD = 1
CALL FFCHAR (IFLD, INTYP, CFIELD, ' ', NAME)
IVAR = LOCSTR (NAME, NVNAMS, NAMES)
IF (IVAR .GT. 0) THEN
CALL PRTERR ('CMDERR', 'ALIAS name must be unique')
GOTO 130
END IF
IVAR = LOCSTR (NAME, NUMALI, NAMALI)
IF (IVAR .GT. 0) THEN
CALL PRTERR ('CMDERR', 'ALIAS name must be unique')
GOTO 130
END IF
IALI = NUMALI + 1
NAMALI(IALI) = NAME
CALL FFADDC (NAME, INLINE)
C --Get and find the first variable name
CALL FFCHAR (IFLD, INTYP, CFIELD, ' ', NAME)
CALL FFADDC (NAME, INLINE)
IVAR = LOCSTR (NAME, NVNAMS, NAMES)
IF (IVAR .GT. 0) THEN
NIXALI(IALI) = 1
IXALI(1,IALI) = IVAR
CALL DBVTYP (IVAR, TYPNAM, IDUM)
ELSE
CALL PRTERR ('CMDERR',
& 'Invalid variable name "' // NAME(:LENSTR(NAME)) // '"')
GOTO 130
END IF
C --If a number follows, assign the next n variables
IF (FFNUMB (IFLD, INTYP)) THEN
CALL FFINTG (IFLD, INTYP, IFIELD,
& 'number of variables', 1, NIXALI(IALI), *130)
CALL FFADDI (NIXALI(IALI), INLINE)
IF (NIXALI(IALI) .GT. MAXALN) THEN
CALL PRTERR ('CMDERR', 'Too many variables to alias')
GOTO 130
END IF
I = IVAR + NIXALI(IALI) - 1
CALL DBVTYP (I, TYP, IDUM)
IF (TYPNAM .NE. TYP) THEN
CALL PRTERR ('CMDERR', 'Variables do not exist')
GOTO 130
END IF
DO 100 I = 1, NIXALI(IALI)
IXALI(I,IALI) = IVAR + I - 1
100 CONTINUE
C --Otherwise assign the named variables
ELSE
110 CONTINUE
IF (FFEXST (IFLD, INTYP)) THEN
CALL FFCHAR (IFLD, INTYP, CFIELD, ' ', NAME)
IVAR = LOCSTR (NAME, NVNAMS, NAMES)
IF (IVAR .GT. 0) THEN
NIXALI(IALI) = NIXALI(IALI) + 1
IF (NIXALI(IALI) .GT. MAXALN) THEN
CALL PRTERR ('CMDERR', 'Too many variables to alias')
GOTO 130
END IF
IXALI(NIXALI(IALI),IALI) = IVAR
CALL DBVTYP (IVAR, TYP, IDUM)
IF (TYPNAM .NE. TYP) THEN
CALL PRTERR ('CMDERR',
& 'Variables must be of the same type')
GOTO 120
END IF
ELSE
CALL PRTERR ('CMDERR',
& 'Invalid variable name' // NAME(:LENSTR(NAME)))
GOTO 120
END IF
CALL FFADDC (NAME, INLINE)
120 CONTINUE
GOTO 110
END IF
END IF
NUMALI = IALI
RETURN
130 CONTINUE
RETURN 1
END