aboutsummaryrefslogtreecommitdiff
path: root/unix/boot/spp/rpp/rppfor/dosub.f
blob: c0efa5cb891235db5cb0380cae5598d71137faf3 (plain) (blame)
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
subroutine dosub (argstk, i, j)
      integer argstk (100), i, j
      common /cdefio/ bp, buf (4096)
      integer bp
      integer buf
      common /cfname/ fcname (30)
      integer fcname
      common /cfor/ fordep, forstk (200)
      integer fordep
      integer forstk
      common /cgoto/ xfer
      integer xfer
      common /clabel/ label, retlab, memflg, col, logic0
      integer label
      integer retlab
      integer memflg
      integer col
      integer logic0
      common /cline/ dbgout, dbglev, level, linect (5), infile (5), fnam
     *p, fnames ( 150)
      integer dbgout
      integer dbglev
      integer level
      integer linect
      integer infile
      integer fnamp
      integer fnames
      common /cmacro/ cp, ep, evalst (500), deftbl
      integer cp
      integer ep
      integer evalst
      integer deftbl
      common /coutln/ outp, outbuf (74)
      integer outp
      integer outbuf
      common /csbuf/ sbp, sbuf(2048), smem(240)
      integer sbp
      integer sbuf
      integer smem
      common /cswtch/ swtop, swlast, swstak(1000), swvnum, swvlev, swvst
     *k(10), swinrg
      integer swtop
      integer swlast
      integer swstak
      integer swvnum
      integer swvlev
      integer swvstk
      integer swinrg
      common /ckword/ rkwtbl
      integer rkwtbl
      common /clname/ fkwtbl, namtbl, gentbl, errtbl, xpptbl
      integer fkwtbl
      integer namtbl
      integer gentbl
      integer errtbl
      integer xpptbl
      common /erchek/ ername, body, esp, errstk(30)
      integer ername
      integer body
      integer esp
      integer errstk
      integer mem( 60000)
      common/cdsmem/mem
      integer ap, fc, k, nc
      integer ctoi, length
      if (.not.(j - i .lt. 3))goto 23000
      return
23000 continue
      if (.not.(j - i .lt. 4))goto 23002
      nc = 100
      goto 23003
23002 continue
      k = argstk (i + 4)
      nc = ctoi (evalst, k)
23003 continue
      k = argstk (i + 3)
      ap = argstk (i + 2)
      fc = ap + ctoi (evalst, k) - 1
      if (.not.(fc .ge. ap .and. fc .lt. ap + length (evalst (ap))))goto
     * 23004
      k = fc + min0(nc, length (evalst (fc))) - 1
23006 if (.not.(k .ge. fc))goto 23008
      call putbak (evalst (k))
23007 k = k - 1
      goto 23006
23008 continue
23004 continue
      return
      end
c     logic0  logical_column