summaryrefslogtreecommitdiff
path: root/module/strinttab.m
diff options
context:
space:
mode:
authorCharles.Forsyth <devnull@localhost>2006-12-22 20:52:35 +0000
committerCharles.Forsyth <devnull@localhost>2006-12-22 20:52:35 +0000
commit46439007cf417cbd9ac8049bb4122c890097a0fa (patch)
tree6fdb25e5f3a2b6d5657eb23b35774b631d4d97e4 /module/strinttab.m
parent37da2899f40661e3e9631e497da8dc59b971cbd0 (diff)
20060303-partial
Diffstat (limited to 'module/strinttab.m')
-rw-r--r--module/strinttab.m17
1 files changed, 17 insertions, 0 deletions
diff --git a/module/strinttab.m b/module/strinttab.m
new file mode 100644
index 00000000..936dcb3b
--- /dev/null
+++ b/module/strinttab.m
@@ -0,0 +1,17 @@
+StringIntTab: module
+{
+ PATH: con "/dis/lib/strinttab.dis";
+
+ StringInt: adt{
+ key: string;
+ val: int;
+ };
+
+ # Binary search of t (which must be sorted) for key.
+ # Returns (found, val).
+ lookup: fn(t: array of StringInt, key: string) : (int, int);
+
+ # Linear search of t for first pair with given val.
+ # Returns key (nil if no match).
+ revlookup: fn(t: array of StringInt, val: int) : string;
+};