diff options
| author | Charles.Forsyth <devnull@localhost> | 2006-12-22 20:52:35 +0000 |
|---|---|---|
| committer | Charles.Forsyth <devnull@localhost> | 2006-12-22 20:52:35 +0000 |
| commit | 46439007cf417cbd9ac8049bb4122c890097a0fa (patch) | |
| tree | 6fdb25e5f3a2b6d5657eb23b35774b631d4d97e4 /module/hash.m | |
| parent | 37da2899f40661e3e9631e497da8dc59b971cbd0 (diff) | |
20060303-partial
Diffstat (limited to 'module/hash.m')
| -rw-r--r-- | module/hash.m | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/module/hash.m b/module/hash.m new file mode 100644 index 00000000..270dd9cd --- /dev/null +++ b/module/hash.m @@ -0,0 +1,23 @@ +Hash: module{ + PATH: con "/dis/lib/hash.dis"; + fun1, fun2: fn(s:string,n:int):int; + + HashVal: adt{ + i: int; + r: real; + s: string; + }; + HashNode: adt{ + key:string; + val:ref HashVal; # insert() can update contents + }; + HashTable: adt{ + a: array of list of HashNode; + find: fn(h:self ref HashTable, key:string):ref HashVal; + insert: fn(h:self ref HashTable, key:string, val:HashVal); + delete: fn(h:self ref HashTable, key:string); + all: fn(h:self ref HashTable): list of HashNode; + }; + new: fn(size:int):ref HashTable; +}; + |
