blob: 56a3d46bba16b0e4b6e735093a41feef61f82518 (
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
|
include defs
# enter --- place a symbol in the symbol table, updating if already present
subroutine enter (symbol, info, st)
character symbol (ARB)
integer info (ARB)
pointer st
DS_DECL(Mem, 1)
integer i, nodsiz, j
integer stlu, length
pointer node, pred
pointer dsget
nodsiz = Mem (st)
if (stlu (symbol, node, pred, st) == NO) {
node = dsget (1 + nodsiz + length (symbol) + 1)
Mem (node + ST_LINK) = LAMBDA
Mem (pred + ST_LINK) = node
i = 1
j = node + ST_DATA + nodsiz
while (symbol (i) != EOS) {
Mem (j) = symbol (i)
i = i + 1
j = j + 1
}
Mem (j) = EOS
}
for (i = 1; i <= nodsiz; i = i + 1) {
j = node + ST_DATA + i - 1
Mem (j) = info (i)
}
return
end
|