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.
100 lines
3.3 KiB
100 lines
3.3 KiB
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
|
|
|