File: bug.f

package info (click to toggle)
nastran 0.1.95-2
  • links: PTS, VCS
  • area: non-free
  • in suites: bookworm, bullseye, sid
  • size: 122,540 kB
  • sloc: fortran: 284,409; sh: 771; makefile: 324
file content (67 lines) | stat: -rw-r--r-- 1,944 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
      SUBROUTINE BUG (NAME,LOC,BUF,NWDS)
C
C     THIS ROUTINE PRINTS NAME,LOC, AND CONTENT OF BUF ARRAY
C     E.G.   CALL BUG ('SUBR ABC',105,CORE(1),120)
C     LIMITED TO 5000 LINES EACH CALL,  14 VALUES PER LINE
C
C     (THIS ROUTINE REPLACES THE OLD ONE IN NASTRAN)
C     WRITTEN BY G.CHAN/SPERRY     MARCH 1986
C
      REAL            BUF(1),   NAME(3)
      CHARACTER*4     A(28),    XLOC,     BLANK
      CHARACTER*8     B(14),    ZERO,     ERR
      COMMON /SYSTEM/ IBUF,     NOUT
      EQUIVALENCE     (A(1),B(1))
      DATA    LINE,   NWPL,     LIMIT              /
     1        0,      14,       5000               /
      DATA    ZERO,   BLANK,    XLOC,     ERR      /
     1        ' 00 ', '    ',   'LOC',    '(ERR)'  /
C
      CALL SSWTCH (20,L)
      IF (L .EQ. 0) RETURN
      GO TO 5
C
      ENTRY BUG1 (NAME,LOC,BUF,NWDS)
C     ==============================
C
 5    IF (NWDS .LT. 0) RETURN
      L = 2
      I = 0
      CALL A42K8 (NAME(1),NAME(2),B(1))
      CALL INT2K8 (*20,LOC,A(3))
      A(4) = A(3)
      A(3) = XLOC
C
 10   IF (I .GE. NWDS) GO TO 60
 15   I = I + 1
      L = L + 1
      J = NUMTYP(BUF(I)) + 1
      GO TO (  25, 30,  35, 40), J
C            ZERO,INT,REAL,BCD
 20   B(L) = ERR
      GO TO 55
 25   B(L) = ZERO
      GO TO 55
 30   CALL INT2K8 (*20,BUF(I),B(L))
      GO TO 55
 35   CALL FP2K8  (*20,BUF(I),B(L))
      GO TO 55
 40   CALL A42K8 (BUF(I),BUF(I+1),B(L))
      IF (NUMTYP(BUF(I+1)) .NE. 3) GO TO 45
      I = I + 1
      GO TO 50
 45   A(L*2) = BLANK
 50   IF (I .GE. NWDS) GO TO 60
 55   IF (L .LT. NWPL) GO TO 10
 60   IF (L .GT. 0) WRITE (NOUT,65) (B(J),J=1,L)
 65   FORMAT (2X,14(A8,1X))
      LINE = LINE + 1
      IF (LINE .GT. LIMIT) GO TO 70
      L = 0
      IF (I .LT. NWDS) GO TO 15
      RETURN
C
 70   WRITE  (NOUT,75) LIMIT
 75   FORMAT (/2X,'PRINT LINES IN BUG EXCEEDS LIMIT OF',I6)
      RETURN
      END