aboutsummaryrefslogtreecommitdiff
path: root/unix/boot/spp/rpp/ratlibr/stlu.r
diff options
context:
space:
mode:
authorJoseph Hunkeler <jhunkeler@gmail.com>2015-07-08 20:46:52 -0400
committerJoseph Hunkeler <jhunkeler@gmail.com>2015-07-08 20:46:52 -0400
commitfa080de7afc95aa1c19a6e6fc0e0708ced2eadc4 (patch)
treebdda434976bc09c864f2e4fa6f16ba1952b1e555 /unix/boot/spp/rpp/ratlibr/stlu.r
downloadiraf-linux-fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4.tar.gz
Initial commit
Diffstat (limited to 'unix/boot/spp/rpp/ratlibr/stlu.r')
-rw-r--r--unix/boot/spp/rpp/ratlibr/stlu.r36
1 files changed, 36 insertions, 0 deletions
diff --git a/unix/boot/spp/rpp/ratlibr/stlu.r b/unix/boot/spp/rpp/ratlibr/stlu.r
new file mode 100644
index 00000000..2f173b1c
--- /dev/null
+++ b/unix/boot/spp/rpp/ratlibr/stlu.r
@@ -0,0 +1,36 @@
+include defs
+
+# stlu --- symbol table lookup primitive
+
+ integer function stlu (symbol, node, pred, st)
+ character symbol (ARB)
+ pointer node, pred, st
+
+ DS_DECL(Mem, 1)
+
+ integer hash, i, j, nodsiz
+
+ nodsiz = Mem (st)
+
+ hash = 0
+ for (i = 1; symbol (i) != EOS; i = i + 1)
+ hash = hash + symbol (i)
+ hash = mod (hash, ST_HTABSIZE) + 1
+
+ pred = st + hash
+ node = Mem (pred)
+ while (node != LAMBDA) {
+ i = 1
+ j = node + ST_DATA + nodsiz
+ while (symbol (i) == Mem (j)) {
+ if (symbol (i) == EOS)
+ return (YES)
+ i = i + 1
+ j = j + 1
+ }
+ pred = node
+ node = Mem (pred + ST_LINK)
+ }
+
+ return (NO)
+ end