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.

101 lines
3.3 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 PRQA (OPTION, NOUT, NQAREC, QAREC, NINFO, INFO)
C=======================================================================
C --*** PRQA *** (EXPLORE) Display QA and information records
C --
C --PRQA displays the QA records and the information records.
C --
C --Parameters:
C -- OPTION - IN - '*' to print all, else print options:
C -- 'Q' to print QA records
C -- 'I' to print information records
C -- NOUT - IN - the output file, <=0 for standard
C -- NQAREC - IN - the number of QA records (must be at least one)
C -- QAREC - IN - the QA records containing:
C -- (1) - the analysis code name
C -- (2) - the analysis code QA descriptor
C -- (3) - the analysis date
C -- (4) - the analysis time
C -- NINFO - IN - the number of information records
C -- INFO - IN - the information records
include 'exodusII.inc'
CHARACTER*(*) OPTION
CHARACTER*(MXSTLN) QAREC(4,*)
CHARACTER*(MXLNLN) INFO(*)
CHARACTER*5 STR5
IF (NOUT .GT. 0) WRITE (*, 10000)
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'Q') .GT. 0)) THEN
IF (NQAREC .GT. 0) THEN
IF (NOUT .GT. 0) THEN
WRITE (NOUT, *)
ELSE
WRITE (*, *)
END IF
IF (NOUT .GT. 0) THEN
CALL INTSTR (1, 0, NQAREC, STR5, LSTR)
WRITE (NOUT, 10010) STR5(:LSTR)
END IF
C ... Find width of largest string
MAXQA = 0
do 90 iqa = 1, nqarec
maxqa = max(maxqa, lenstr(qarec(1,iqa)))
maxqa = max(maxqa, lenstr(qarec(2,iqa)))
maxqa = max(maxqa, lenstr(qarec(3,iqa)))
maxqa = max(maxqa, lenstr(qarec(4,iqa)))
90 continue
DO 100 IQA = 1, NQAREC
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10020) (QAREC(I,IQA)(:MAXQA), I=1,4)
ELSE
WRITE (*, 10020) (QAREC(I,IQA)(:MAXQA), I=1,4)
END IF
100 CONTINUE
END IF
END IF
IF ((OPTION .EQ. '*') .OR. (INDEX (OPTION, 'I') .GT. 0)) THEN
IF (NINFO .GT. 0) THEN
IF (NOUT .GT. 0) THEN
WRITE (NOUT, *)
ELSE
WRITE (*, *)
END IF
IF (NOUT .GT. 0) THEN
CALL INTSTR (1, 0, NINFO, STR5, LSTR)
WRITE (NOUT, 10030) STR5(:LSTR)
END IF
DO 110 I = 1, NINFO
IF (NOUT .GT. 0) THEN
WRITE (NOUT, 10040) INFO(I)(:LENSTR(INFO(I)))
ELSE
WRITE (*, 10040) INFO(I)(:LENSTR(INFO(I)))
END IF
110 CONTINUE
END IF
END IF
RETURN
10000 FORMAT (/, 1X, 'QA AND INFORMATION RECORDS')
10010 FORMAT (/, 1X, 'Number of QA Records = ', A)
10020 FORMAT (1X, 'Code: ', A, ' version ', A,
& ' on ', A, ' at ', A)
10030 FORMAT (/, 1X, 'Number of Information Records = ', A)
10040 FORMAT (1X, A)
END