File: print.f

package info (click to toggle)
nastran 0.1.95-2
  • links: PTS, VCS
  • area: non-free
  • in suites: bookworm, bullseye
  • size: 122,540 kB
  • sloc: fortran: 284,409; sh: 771; makefile: 324
file content (62 lines) | stat: -rw-r--r-- 1,755 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
      SUBROUTINE PRINT (X,Y,XYD,CHR,N,OPT)
C
C     (X,Y) = STARTING OR ENDING POINT OF THE LINE TO BE PRINTED (ALWAYS
C             LEFT-TO-RIGHT OR TOP-TO-BOTTOM).
C     CHR   = CHARACTERS TO BE PRINTED (4 PER WORD).
C     N     = NUMBER OF 4 CHARACTER WORDS.
C     XYD   = +/-1 IF X = STARTING OR ENDING POINT OF THE LINE.
C     ...   = +/-2 .. Y = ........ .. ...... ..... .. ... .....
C     OPT   = -1 TO INITIATE  THE TYPING MODE.
C     ...   = +1 .. TERMINATE ... ...... .....
C     ...   =  0 .. PRINT A LINE.
C
      EXTERNAL        ORF,KRSHFT,KLSHFT
      INTEGER         XYD,CHR(1),OPT,ORF,C(80),BLANK,BLNK,CHARX,D
      REAL            XY(2,2)
      COMMON /PLTDAT/ SKPPLT(20),SKPA(3),CNTCHR(2)
      COMMON /SYSTEM/ SKPSYS(40),NCPW
      DATA    BLANK / 1H /
C
      IF (OPT .NE. 0) GO TO 150
      BLNK = KRSHFT(KLSHFT(BLANK,1),1)
      D = MAX0(IABS(XYD),1)
      S = CNTCHR(D)
      IF (XYD.EQ.-1 .OR. XYD.EQ.2) S = -S
      XY(1,1) = X
      XY(2,1) = Y
      XY(1,2) = XY(1,1)
      XY(2,2) = XY(2,1)
C
C     SEPARATE 80 CHARACTERS AT A TIME.
C
      DO 130 J = 1,N,20
      IF (XYD .LT. 0) GO TO 105
      L1 = J
      L2 = L1 + 19
      IF (L2 .GT. N) L2 = N
      GO TO 106
  105 L2 = N - J + 1
      L1 = L2 - 19
      IF (L1 .LE. 0) L1 = 1
C
  106 NC = 0
      DO 120 L = L1,L2
      DO 110 I = 1,4
      CHARX = KRSHFT(CHR(L),NCPW-I)
      NC = NC + 1
      C(NC) = ORF(KLSHFT(CHARX,NCPW-1),BLNK)
  110 CONTINUE
  120 CONTINUE
C
C     TYPE THE -NC- CHARACTERS JUST SEPARATED.
C
      XY(D,2) = XY(D,1) + S*FLOAT(L1-1)
      CALL TIPE (XY(1,2),XY(2,2),XYD,C,NC,0)
  130 CONTINUE
      GO TO 200
C
C     OPT = +/-1
C
  150 CALL TIPE (0,0,0,0,0,OPT)
  200 RETURN
      END