-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathls9-litpool.nw
77 lines (69 loc) · 1.28 KB
/
ls9-litpool.nw
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
Compiler, literal pool
<<ls9 globals>>=
full Obhash = NIL,
Obarray = NIL,
Obmap = NIL,
Obptr = 0;
@
<<ls9 impl>>=
full obslot(void) {
full i, j, k, m, n;
byte *s;
for (m = 0; m < 2; m++) {
for (j = 0; j < 2; j++) {
k = veclen(Obarray);
s = string(Obmap);
for (i=0; i<k; i++) {
if (OBFREE == s[Obptr]) {
s[Obptr] = OBALLOC;
return Obptr;
}
Obptr++;
if (Obptr >= k) Obptr = 0;
}
if (0 == j) gc();
}
if (k + CHUNKSIZE >= 64 * 1024) break;
n = mkvec(k + CHUNKSIZE);
memcpy(vector(n), vector(Obarray), k * sizeof(full));
Obarray = n;
n = mkstr(NULL, k + CHUNKSIZE);
memset(string(n), OBFREE, k+CHUNKSIZE);
memcpy(string(n), string(Obmap), k);
Obmap = n;
}
error("out of object space", UNDEF);
return NIL;
}
full obindex(full x) {
full n;
full i;
if (pairp(x) || vectorp(x) || closurep(x))
return obslot();
n = htlookup(Obhash, x);
if (n != UNDEF) {
i = fixval(cdr(n));
if ( string(Obmap)[i] != OBFREE &&
match(x, vector(Obarray)[i])
)
return i;
htrem(Obhash, x);
}
i = obslot();
htadd(Obhash, x, mkfix(i));
return i;
}
full subprog(full x, full k) {
full n, i, j;
byte *sx, *sn;
n = mkstr(NULL, k);
sx = string(x);
sn = string(n);
j = 0;
for (i=0; i<k; i++) {
sn[j] = sx[i];
j++;
}
return n;
}
@