aboutsummaryrefslogtreecommitdiff
path: root/unix/boot/spp/rpp/rppfor/lex.f
blob: 6f2243f4df2a6b02089c3f8278b0df4f637dafe1 (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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
integer function lex (lexstr)
      integer lexstr (100)
      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 gnbtok, t, c
      integer lookup, n
      integer sdefa0(8)
      data sdefa0(1)/100/,sdefa0(2)/101/,sdefa0(3)/102/,sdefa0(4)/97/,sd
     *efa0(5)/117/,sdefa0(6)/108/,sdefa0(7)/116/,sdefa0(8)/-2/
      lex = gnbtok (lexstr, 100)
23000 if (.not.(lex .eq. 10))goto 23002
23001  lex = gnbtok (lexstr, 100)
      goto 23000
23002 continue
      if (.not.(lex .eq. -1 .or. lex .eq. 59 .or. lex .eq. 123 .or. lex 
     *.eq. 125))goto 23003
      return
23003 continue
      if (.not.(lex .eq. 48))goto 23005
      lex = -89
      goto 23006
23005 continue
      if (.not.(lex .eq. 37))goto 23007
      lex = -85
      goto 23008
23007 continue
      if (.not.(lex .eq.  -166))goto 23009
      lex = -67
      goto 23010
23009 continue
      if (.not.(lookup (lexstr, lex, rkwtbl) .eq. 1))goto 23011
      if (.not.(lex .eq. -90))goto 23013
      n = -1
23015 continue
      c = ngetch (c)
      n = n + 1
23016 if (.not.(c .ne. 32 .and. c .ne. 9))goto 23015
23017 continue
      call putbak (c)
      t = gnbtok (lexstr, 100)
      call pbstr (lexstr)
      if (.not.(n .gt. 0))goto 23018
      call putbak (32)
23018 continue
      call scopy (sdefa0, 1, lexstr, 1)
      if (.not.(t .ne. 58))goto 23020
      lex = -80
23020 continue
23013 continue
      goto 23012
23011 continue
      lex = -80
23012 continue
23010 continue
23008 continue
23006 continue
      return
      end
c     logic0  logical_column
c     sdefa0  sdefault